
<!DOCTYPE HTML>
<html lang="zh-hans" >
    <head>
        <meta charset="UTF-8">
        <meta content="text/html; charset=utf-8" http-equiv="Content-Type">
        <title>Vue.js · 千锋大前端小册-企业面试真题</title>
        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
        <meta name="description" content="">
        <meta name="generator" content="GitBook 3.2.3">
        <meta name="author" content="古艺散人">
        
        
    
    <link rel="stylesheet" href="../gitbook/style.css">

    
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-splitter/splitter.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-expandable-chapters-small/expandable-chapters-small.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-anchors/plugin.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-anchor-navigation-ex/style/plugin.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-insert-logo/plugin.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-highlight/website.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-search/search.css">
                
            
                
                <link rel="stylesheet" href="../gitbook/gitbook-plugin-fontsettings/website.css">
                
            
        

    

    
        
    

        
    
    
    
    
    <meta name="HandheldFriendly" content="true"/>
    <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <link rel="apple-touch-icon-precomposed" sizes="152x152" href="../gitbook/images/apple-touch-icon-precomposed-152.png">
    <link rel="shortcut icon" href="../gitbook/images/favicon.ico" type="image/x-icon">

    
    <link rel="next" href="../react/" />
    
    
    <link rel="prev" href="../node/" />
    

    
        <link rel="shortcut icon" href='../source/images/favicon.jpg' type="image/x-icon">
    
    
        <link rel="bookmark" href='../source/images/favicon.jpg' type="image/x-icon">
    
    
        <link rel="apple-touch-icon" href='../source/images/apple-touch-icon.jpg'>
    
    
        
        <link rel="apple-touch-icon" sizes="120x120" href="../source/images/apple-touch-icon.jpg">
        
        <link rel="apple-touch-icon" sizes="180x180" href="../source/images/apple-touch-icon.jpg">
        
    

    <style>
    @media only screen and (max-width: 640px) {
        .book-header .hidden-mobile {
            display: none;
        }
    }
    </style>
    <script>
        window["gitbook-plugin-github-buttons"] = {"buttons":[{"user":"lurongtao","repo":"felixbooks-interview","type":"star","size":"small","count":true}]};
    </script>

    </head>
    <body>
        
<div class="book">
    <div class="book-summary">
        
            
<div id="book-search-input" role="search">
    <input type="text" placeholder="输入并搜索" />
</div>

            
                <nav role="navigation">
                


<ul class="summary">
    
    

    

    
        
        
    
        <li class="chapter " data-level="1.1" data-path="../">
            
                <a href="../">
            
                    
                    前言
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.2" data-path="../HTML+CSS/">
            
                <a href="../HTML+CSS/">
            
                    
                    HTML5+CSS3
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.3" data-path="../javascript/">
            
                <a href="../javascript/">
            
                    
                    JavaScript
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.4" data-path="../node/">
            
                <a href="../node/">
            
                    
                    Node.js
            
                </a>
            

            
        </li>
    
        <li class="chapter active" data-level="1.5" data-path="./">
            
                <a href="./">
            
                    
                    Vue.js
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.6" data-path="../react/">
            
                <a href="../react/">
            
                    
                    React
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.7" data-path="../weapp/">
            
                <a href="../weapp/">
            
                    
                    小程序
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.8" data-path="../browser/">
            
                <a href="../browser/">
            
                    
                    浏览器
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.9" data-path="../network/">
            
                <a href="../network/">
            
                    
                    网络
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.10" data-path="../engineering/">
            
                <a href="../engineering/">
            
                    
                    前端工程化
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.11" data-path="../performance/">
            
                <a href="../performance/">
            
                    
                    性能
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.12" data-path="../security/">
            
                <a href="../security/">
            
                    
                    安全
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.13" data-path="../handwritten/">
            
                <a href="../handwritten/">
            
                    
                    手写代码
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.14" data-path="../algorithm/">
            
                <a href="../algorithm/">
            
                    
                    高频算法
            
                </a>
            

            
        </li>
    
        <li class="chapter " data-level="1.15" data-path="../others/">
            
                <a href="../others/">
            
                    
                    综合
            
                </a>
            

            
        </li>
    

    
        
        <li class="divider"></li>
        
        
    
        <li class="chapter " data-level="2.1" data-path="../thanks/">
            
                <a href="../thanks/">
            
                    
                    感谢
            
                </a>
            

            
        </li>
    

    

    <li class="divider"></li>

    <li>
        <a href="https://www.gitbook.com" target="blank" class="gitbook-link">
            本书使用 GitBook 发布
        </a>
    </li>
</ul>


                </nav>
            
        
    </div>

    <div class="book-body">
        
            <div class="body-inner">
                
                    

<div class="book-header" role="navigation">
    

    <!-- Title -->
    <h1>
        <i class="fa fa-circle-o-notch fa-spin"></i>
        <a href=".." >Vue.js</a>
    </h1>
</div>




                    <div class="page-wrapper" tabindex="-1" role="main">
                        <div class="page-inner">
                            
<div id="book-search-results">
    <div class="search-noresults">
    
                                <section class="normal markdown-section">
                                
                                <div id="anchor-navigation-ex-navbar"><i class="fa fa-navicon"></i><ul><li><span class="title-icon "></span><a href="#&#x76EE;&#x5F55;"><b></b>&#x76EE;&#x5F55;</a></li></ul></div><a href="#&#x76EE;&#x5F55;" id="anchorNavigationExGoTop"><i class="fa fa-arrow-up"></i></a><h1 id="&#x76EE;&#x5F55;"><a name="&#x76EE;&#x5F55;" class="anchor-navigation-ex-anchor" href="#&#x76EE;&#x5F55;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="&#x76EE;&#x5F55;" class="plugin-anchor" href="#&#x76EE;&#x5F55;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x76EE;&#x5F55;</h1>
<h5 id="1-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x518D;vue&#x7684;&#x5355;&#x6587;&#x4EF6;&#x7EC4;&#x4EF6;&#x91CC;&#x7684;&#x6837;&#x5F0F;&#x5B9A;&#x4E49;&#x5168;&#x5C40;css&#xFF1F;"><a name="1-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x518D;vue&#x7684;&#x5355;&#x6587;&#x4EF6;&#x7EC4;&#x4EF6;&#x91CC;&#x7684;&#x6837;&#x5F0F;&#x5B9A;&#x4E49;&#x5168;&#x5C40;css&#xFF1F;" class="anchor-navigation-ex-anchor" href="#1-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x518D;vue&#x7684;&#x5355;&#x6587;&#x4EF6;&#x7EC4;&#x4EF6;&#x91CC;&#x7684;&#x6837;&#x5F0F;&#x5B9A;&#x4E49;&#x5168;&#x5C40;css&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="1-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x518D;vue&#x7684;&#x5355;&#x6587;&#x4EF6;&#x7EC4;&#x4EF6;&#x91CC;&#x7684;&#x6837;&#x5F0F;&#x5B9A;&#x4E49;&#x5168;&#x5C40;css&#xFF1F;" class="plugin-anchor" href="#1-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x518D;vue&#x7684;&#x5355;&#x6587;&#x4EF6;&#x7EC4;&#x4EF6;&#x91CC;&#x7684;&#x6837;&#x5F0F;&#x5B9A;&#x4E49;&#x5168;&#x5C40;css&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>1. &#x2605;&#x2605;&#x2605; &#x5982;&#x4F55;&#x518D;Vue&#x7684;&#x5355;&#x6587;&#x4EF6;&#x7EC4;&#x4EF6;&#x91CC;&#x7684;&#x6837;&#x5F0F;&#x5B9A;&#x4E49;&#x5168;&#x5C40;CSS&#xFF1F;</h5>
<pre><code class="lang-JS">&#x5728;style&#x6807;&#x7B7E;&#x4E0A;&#x4E0D;&#x52A0;&#x4E0A;scoped&#x7684;&#x5C5E;&#x6027;&#xFF0C;&#x9ED8;&#x8BA4;&#x4E3A;&#x5168;&#x5C40;css&#x6837;&#x5F0F;
</code></pre>
<h5 id="2-&#x2605;&#x2605;-vue-router-310-router-link&#x65B0;&#x589E;&#x7684;v-slot&#x5C5E;&#x6027;&#x600E;&#x4E48;&#x7528;&#xFF1F;"><a name="2-&#x2605;&#x2605;-vue-router-310-router-link&#x65B0;&#x589E;&#x7684;v-slot&#x5C5E;&#x6027;&#x600E;&#x4E48;&#x7528;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#2-&#x2605;&#x2605;-vue-router-310-router-link&#x65B0;&#x589E;&#x7684;v-slot&#x5C5E;&#x6027;&#x600E;&#x4E48;&#x7528;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="2-&#x2605;&#x2605;-vue-router-310-router-link&#x65B0;&#x589E;&#x7684;v-slot&#x5C5E;&#x6027;&#x600E;&#x4E48;&#x7528;&#xFF1F;" class="plugin-anchor" href="#2-&#x2605;&#x2605;-vue-router-310-router-link&#x65B0;&#x589E;&#x7684;v-slot&#x5C5E;&#x6027;&#x600E;&#x4E48;&#x7528;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>2. &#x2605;&#x2605; vue-router 3.1.0 <code>&lt;router-link&gt;</code>&#x65B0;&#x589E;&#x7684;v-slot&#x5C5E;&#x6027;&#x600E;&#x4E48;&#x7528;&#xFF1F;</h5>
<pre><code class="lang-JS">router-link &#x901A;&#x8FC7;&#x4E00;&#x4E2A;&#x4F5C;&#x7528;&#x57DF;&#x63D2;&#x69FD;&#x66B4;&#x9732;&#x5E95;&#x5C42;&#x7684;&#x5B9A;&#x5236;&#x80FD;&#x529B;&#x3002;&#x8FD9;&#x662F;&#x4E00;&#x4E2A;&#x66F4;&#x9AD8;&#x9636;&#x7684; API&#xFF0C;&#x4E3B;&#x8981;&#x9762;&#x5411;&#x5E93;&#x4F5C;&#x8005;&#xFF0C;&#x4F46;&#x4E5F;&#x53EF;&#x4EE5;&#x4E3A;&#x5F00;&#x53D1;&#x8005;&#x63D0;&#x4F9B;&#x4FBF;&#x5229;&#xFF0C;&#x591A;&#x6570;&#x60C5;&#x51B5;&#x7528;&#x5728;&#x4E00;&#x4E2A;&#x7C7B;&#x4F3C; NavLink &#x8FD9;&#x6837;&#x7684;&#x81EA;&#x5B9A;&#x4E49;&#x7EC4;&#x4EF6;&#x91CC;&#x3002;

&#x5728;&#x4F7F;&#x7528; v-slot API &#x65F6;&#xFF0C;&#x9700;&#x8981;&#x5411; router-link &#x4F20;&#x5165;&#x4E00;&#x4E2A;&#x5355;&#x72EC;&#x7684;&#x5B50;&#x5143;&#x7D20;&#x3002;&#x5426;&#x5219; router-link &#x5C06;&#x4F1A;&#x628A;&#x5B50;&#x5143;&#x7D20;&#x5305;&#x88F9;&#x5728;&#x4E00;&#x4E2A; span &#x5143;&#x7D20;&#x5185;&#x3002;
</code></pre>
<h5 id="3-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x4E00;&#x4E2A;&#x8DEF;&#x5F84;&#x6E32;&#x67D3;&#x591A;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF1F;"><a name="3-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x4E00;&#x4E2A;&#x8DEF;&#x5F84;&#x6E32;&#x67D3;&#x591A;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#3-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x4E00;&#x4E2A;&#x8DEF;&#x5F84;&#x6E32;&#x67D3;&#x591A;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="3-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x4E00;&#x4E2A;&#x8DEF;&#x5F84;&#x6E32;&#x67D3;&#x591A;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF1F;" class="plugin-anchor" href="#3-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x4E00;&#x4E2A;&#x8DEF;&#x5F84;&#x6E32;&#x67D3;&#x591A;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>3. &#x2605;&#x2605;&#x2605; &#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x4E00;&#x4E2A;&#x8DEF;&#x5F84;&#x6E32;&#x67D3;&#x591A;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF1F;</h5>
<pre><code class="lang-JS">&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x547D;&#x540D;&#x89C6;&#x56FE;(router-view)&#xFF0C;&#x5B83;&#x5BB9;&#x8BB8;&#x540C;&#x4E00;&#x754C;&#x9762;&#x4E2D;&#x62E5;&#x6709;&#x591A;&#x4E2A;&#x5355;&#x72EC;&#x547D;&#x540D;&#x7684;&#x89C6;&#x56FE;&#xFF0C;&#x800C;&#x4E0D;&#x662F;&#x53EA;&#x6709;&#x4E00;&#x4E2A;&#x5355;&#x72EC;&#x7684;&#x51FA;&#x53E3;&#x3002;&#x5982;&#x679C; router-view &#x6CA1;&#x6709;&#x8BBE;&#x7F6E;&#x540D;&#x5B57;&#xFF0C;&#x90A3;&#x4E48;&#x9ED8;&#x8BA4;&#x4E3A; <span class="hljs-keyword">default</span>&#x3002;&#x901A;&#x8FC7;&#x8BBE;&#x7F6E;components&#x5373;&#x53EF;&#x540C;&#x65F6;&#x6E32;&#x67D3;&#x591A;&#x4E2A;&#x7EC4;&#x4EF6;&#x3002;
</code></pre>
<h5 id="4-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x591A;&#x4E2A;&#x8DEF;&#x5F84;&#x5171;&#x4EAB;&#x4E00;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF1F;"><a name="4-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x591A;&#x4E2A;&#x8DEF;&#x5F84;&#x5171;&#x4EAB;&#x4E00;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#4-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x591A;&#x4E2A;&#x8DEF;&#x5F84;&#x5171;&#x4EAB;&#x4E00;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="4-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x591A;&#x4E2A;&#x8DEF;&#x5F84;&#x5171;&#x4EAB;&#x4E00;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF1F;" class="plugin-anchor" href="#4-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x591A;&#x4E2A;&#x8DEF;&#x5F84;&#x5171;&#x4EAB;&#x4E00;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>4. &#x2605;&#x2605;&#x2605; &#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x591A;&#x4E2A;&#x8DEF;&#x5F84;&#x5171;&#x4EAB;&#x4E00;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF1F;</h5>
<pre><code class="lang-JS">&#x53EA;&#x9700;&#x5C06;&#x591A;&#x4E2A;&#x8DEF;&#x5F84;&#x7684;component&#x5B57;&#x6BB5;&#x7684;&#x503C;&#x8BBE;&#x7F6E;&#x4E3A;&#x540C;&#x4E00;&#x4E2A;&#x7EC4;&#x4EF6;&#x5373;&#x53EF;&#x3002;
</code></pre>
<h5 id="5-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x76D1;&#x6D4B;&#x52A8;&#x6001;&#x8DEF;&#x7531;&#x7684;&#x53D8;&#x5316;"><a name="5-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x76D1;&#x6D4B;&#x52A8;&#x6001;&#x8DEF;&#x7531;&#x7684;&#x53D8;&#x5316;" class="anchor-navigation-ex-anchor" href="#5-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x76D1;&#x6D4B;&#x52A8;&#x6001;&#x8DEF;&#x7531;&#x7684;&#x53D8;&#x5316;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="5-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x76D1;&#x6D4B;&#x52A8;&#x6001;&#x8DEF;&#x7531;&#x7684;&#x53D8;&#x5316;" class="plugin-anchor" href="#5-&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x76D1;&#x6D4B;&#x52A8;&#x6001;&#x8DEF;&#x7531;&#x7684;&#x53D8;&#x5316;"><i class="fa fa-link" aria-hidden="true"></i></a>5. &#x2605;&#x2605;&#x2605; &#x5982;&#x4F55;&#x76D1;&#x6D4B;&#x52A8;&#x6001;&#x8DEF;&#x7531;&#x7684;&#x53D8;&#x5316;</h5>
<pre><code class="lang-JS">&#x53EF;&#x4EE5;&#x901A;&#x8FC7;watch&#x65B9;&#x6CD5;&#x6765;&#x5BF9;$route&#x8FDB;&#x884C;&#x76D1;&#x542C;&#xFF0C;&#x6216;&#x8005;&#x901A;&#x8FC7;&#x5BFC;&#x822A;&#x5B88;&#x536B;&#x7684;&#x94A9;&#x5B50;&#x51FD;&#x6570;beforeRouteUpdate&#x6765;&#x76D1;&#x542C;&#x5B83;&#x7684;&#x53D8;&#x5316;&#x3002;
</code></pre>
<h5 id="6-&#x2605;&#x2605;&#x2605;-&#x5BF9;mvc&#xFF0C;mvp&#xFF0C;mvvm&#x7684;&#x7406;&#x89E3;"><a name="6-&#x2605;&#x2605;&#x2605;-&#x5BF9;mvc&#xFF0C;mvp&#xFF0C;mvvm&#x7684;&#x7406;&#x89E3;" class="anchor-navigation-ex-anchor" href="#6-&#x2605;&#x2605;&#x2605;-&#x5BF9;mvc&#xFF0C;mvp&#xFF0C;mvvm&#x7684;&#x7406;&#x89E3;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="6-&#x2605;&#x2605;&#x2605;-&#x5BF9;mvc&#xFF0C;mvp&#xFF0C;mvvm&#x7684;&#x7406;&#x89E3;" class="plugin-anchor" href="#6-&#x2605;&#x2605;&#x2605;-&#x5BF9;mvc&#xFF0C;mvp&#xFF0C;mvvm&#x7684;&#x7406;&#x89E3;"><i class="fa fa-link" aria-hidden="true"></i></a>6. &#x2605;&#x2605;&#x2605; &#x5BF9;MVC&#xFF0C;MVP&#xFF0C;MVVM&#x7684;&#x7406;&#x89E3;</h5>
<pre><code class="lang-JS">mvc &#x548C; mvvm &#x5176;&#x5B9E;&#x533A;&#x522B;&#x5E76;&#x4E0D;&#x5927;&#x3002;&#x90FD;&#x662F;&#x4E00;&#x79CD;&#x8BBE;&#x8BA1;&#x601D;&#x60F3;&#x3002;&#x4E3B;&#x8981;&#x5C31;&#x662F; mvc &#x4E2D; Controller &#x6F14;&#x53D8;&#x6210; mvvm &#x4E2D;&#x7684; viewModel&#x3002;mvvm &#x4E3B;&#x8981;&#x89E3;&#x51B3;&#x4E86; mvc &#x4E2D;&#x5927;&#x91CF;&#x7684; DOM &#x64CD;&#x4F5C;&#x4F7F;&#x9875;&#x9762;&#x6E32;&#x67D3;&#x6027;&#x80FD;&#x964D;&#x4F4E;&#xFF0C;&#x52A0;&#x8F7D;&#x901F;&#x5EA6;&#x53D8;&#x6162;&#xFF0C;&#x5F71;&#x54CD;&#x7528;&#x6237;&#x4F53;&#x9A8C;&#x3002;&#x548C;&#x5F53; Model &#x9891;&#x7E41;&#x53D1;&#x751F;&#x53D8;&#x5316;&#xFF0C;&#x5F00;&#x53D1;&#x8005;&#x9700;&#x8981;&#x4E3B;&#x52A8;&#x66F4;&#x65B0;&#x5230; View &#x3002;

MVVM &#x662F; Model-View-ViewModel &#x7684;&#x7F29;&#x5199;&#x3002;mvvm &#x662F;&#x4E00;&#x79CD;&#x8BBE;&#x8BA1;&#x601D;&#x60F3;&#x3002;
<span class="hljs-number">1</span>&#xFF1A;Model &#x5C42;&#x4EE3;&#x8868;&#x6570;&#x636E;&#x6A21;&#x578B;&#xFF0C;&#x4E5F;&#x53EF;&#x4EE5;&#x5728; Model &#x4E2D;&#x5B9A;&#x4E49;&#x6570;&#x636E;&#x4FEE;&#x6539;&#x548C;&#x64CD;&#x4F5C;&#x7684;&#x4E1A;&#x52A1;&#x903B;&#x8F91;&#xFF1B;View &#x4EE3;&#x8868; UI &#x7EC4;&#x4EF6;&#xFF0C;&#x5B83;&#x8D1F;&#x8D23;&#x5C06;&#x6570;&#x636E;&#x6A21;&#x578B;&#x8F6C;&#x5316;&#x6210; UI &#x5C55;&#x73B0;&#x51FA;&#x6765;&#xFF0C;ViewModel &#x662F;&#x4E00;&#x4E2A;&#x540C;&#x6B65; View &#x548C; Model &#x7684;&#x5BF9;&#x8C61;&#x3002;
<span class="hljs-number">2</span>&#xFF1A;&#x5728; MVVM &#x67B6;&#x6784;&#x4E0B;&#xFF0C;View &#x548C; Model &#x4E4B;&#x95F4;&#x5E76;&#x6CA1;&#x6709;&#x76F4;&#x63A5;&#x7684;&#x8054;&#x7CFB;&#xFF0C;&#x800C;&#x662F;&#x901A;&#x8FC7; ViewModel &#x8FDB;&#x884C;&#x4EA4;&#x4E92;&#xFF0C;Model &#x548C; ViewModel &#x4E4B;&#x95F4;&#x7684;&#x4EA4;&#x4E92;&#x662F;&#x53CC;&#x5411;&#x7684;&#xFF0C; &#x56E0;&#x6B64; View &#x6570;&#x636E;&#x7684;&#x53D8;&#x5316;&#x4F1A;&#x540C;&#x6B65;&#x5230; Model &#x4E2D;&#xFF0C;&#x800C; Model &#x6570;&#x636E;&#x7684;&#x53D8;&#x5316;&#x4E5F;&#x4F1A;&#x7ACB;&#x5373;&#x53CD;&#x5E94;&#x5230; View &#x4E0A;&#x3002;
<span class="hljs-number">3</span>&#xFF1A;ViewModel &#x901A;&#x8FC7;&#x53CC;&#x5411;&#x6570;&#x636E;&#x7ED1;&#x5B9A;&#x628A; View &#x5C42;&#x548C; Model &#x5C42;&#x8FDE;&#x63A5;&#x4E86;&#x8D77;&#x6765;&#xFF0C;&#x800C; View &#x548C; Model &#x4E4B;&#x95F4;&#x7684;&#x540C;&#x6B65;&#x5DE5;&#x4F5C;&#x5B8C;&#x5168;&#x662F;&#x81EA;&#x52A8;&#x7684;&#xFF0C;&#x65E0;&#x9700;&#x4EBA;&#x4E3A;&#x5E72;&#x6D89;&#xFF0C;&#x56E0;&#x6B64;&#x5F00;&#x53D1;&#x8005;&#x53EA;&#x9700;&#x5173;&#x6CE8;&#x4E1A;&#x52A1;&#x903B;&#x8F91;&#xFF0C;&#x4E0D;&#x9700;&#x8981;&#x624B;&#x52A8;&#x64CD;&#x4F5C; DOM, &#x4E0D;&#x9700;&#x8981;&#x5173;&#x6CE8;&#x6570;&#x636E;&#x72B6;&#x6001;&#x7684;&#x540C;&#x6B65;&#x95EE;&#x9898;&#xFF0C;&#x590D;&#x6742;&#x7684;&#x6570;&#x636E;&#x72B6;&#x6001;&#x7EF4;&#x62A4;&#x5B8C;&#x5168;&#x7531; MVVM &#x6765;&#x7EDF;&#x4E00;&#x7BA1;&#x7406;&#x3002;
</code></pre>
<h5 id="7-&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;root&#xFF0C;parent&#xFF0C;refs"><a name="7-&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;root&#xFF0C;parent&#xFF0C;refs" class="anchor-navigation-ex-anchor" href="#7-&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;root&#xFF0C;parent&#xFF0C;refs"><i class="fa fa-link" aria-hidden="true"></i></a><a name="7-&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;root&#xFF0C;parent&#xFF0C;refs" class="plugin-anchor" href="#7-&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;root&#xFF0C;parent&#xFF0C;refs"><i class="fa fa-link" aria-hidden="true"></i></a>7. &#x2605;&#x2605; &#x8BF4;&#x4E00;&#x4E0B;$root&#xFF0C;$parent&#xFF0C;$refs</h5>
<pre><code class="lang-JS">$root&#xFF0C;&#x548C;$parent&#x90FD;&#x80FD;&#x8BBF;&#x95EE;&#x7236;&#x7EC4;&#x4EF6;&#x7684;&#x5C5E;&#x6027;&#x548C;&#x65B9;&#x6CD5;&#xFF0C;&#x533A;&#x522B;&#x5728;&#x4E8E;&#x5982;&#x679C;&#x5B58;&#x5728;&#x591A;&#x7EA7;&#x5B50;&#x7EC4;&#x4EF6;&#xFF0C;&#x901A;&#x8FC7;parent &#x8BBF;&#x95EE;&#x5F97;&#x5230;&#x7684;&#x662F;&#x5B83;&#x6700;&#x8FD1;&#x4E00;&#x7EA7;&#x7684;&#x7236;&#x7EC4;&#x4EF6;&#xFF0C;&#x901A;&#x8FC7;root &#x8BBF;&#x95EE;&#x5F97;&#x5230;&#x7684;&#x662F;&#x6839;&#x7236;&#x7EC4;&#x4EF6;&#x3002;&#x901A;&#x8FC7;&#x5728;&#x5B50;&#x7EC4;&#x4EF6;&#x6807;&#x7B7E;&#x5B9A;&#x4E49; ref &#x5C5E;&#x6027;&#xFF0C;&#x5728;&#x7236;&#x7EC4;&#x4EF6;&#x4E2D;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;$refs &#x8BBF;&#x95EE;&#x5B50;&#x7EC4;&#x4EF6;&#x5B9E;&#x4F8B;&#x3002;
</code></pre>
<h5 id="8-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-&#x4F60;&#x77E5;&#x9053;vue&#x54CD;&#x5E94;&#x5F0F;&#x6570;&#x636E;&#x539F;&#x7406;&#x5417;&#xFF1F;proxy-&#x4E0E;-objectdefineproperty-&#x4F18;&#x52A3;&#x5BF9;&#x6BD4;&#xFF1F;"><a name="8-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-&#x4F60;&#x77E5;&#x9053;vue&#x54CD;&#x5E94;&#x5F0F;&#x6570;&#x636E;&#x539F;&#x7406;&#x5417;&#xFF1F;proxy-&#x4E0E;-objectdefineproperty-&#x4F18;&#x52A3;&#x5BF9;&#x6BD4;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#8-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-&#x4F60;&#x77E5;&#x9053;vue&#x54CD;&#x5E94;&#x5F0F;&#x6570;&#x636E;&#x539F;&#x7406;&#x5417;&#xFF1F;proxy-&#x4E0E;-objectdefineproperty-&#x4F18;&#x52A3;&#x5BF9;&#x6BD4;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="8-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-&#x4F60;&#x77E5;&#x9053;vue&#x54CD;&#x5E94;&#x5F0F;&#x6570;&#x636E;&#x539F;&#x7406;&#x5417;&#xFF1F;proxy-&#x4E0E;-objectdefineproperty-&#x4F18;&#x52A3;&#x5BF9;&#x6BD4;&#xFF1F;" class="plugin-anchor" href="#8-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-&#x4F60;&#x77E5;&#x9053;vue&#x54CD;&#x5E94;&#x5F0F;&#x6570;&#x636E;&#x539F;&#x7406;&#x5417;&#xFF1F;proxy-&#x4E0E;-objectdefineproperty-&#x4F18;&#x52A3;&#x5BF9;&#x6BD4;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>8. &#x2605;&#x2605;&#x2605;&#x2605;&#x2605; &#x4F60;&#x77E5;&#x9053;Vue&#x54CD;&#x5E94;&#x5F0F;&#x6570;&#x636E;&#x539F;&#x7406;&#x5417;&#xFF1F;Proxy &#x4E0E; Object.defineProperty &#x4F18;&#x52A3;&#x5BF9;&#x6BD4;&#xFF1F;</h5>
<pre><code class="lang-JS"><span class="hljs-comment">// &#x54CD;&#x5E94;&#x5F0F;&#x539F;&#x7406;</span>

vue&#x7684;&#x54CD;&#x5E94;&#x5F0F;&#x5B9E;&#x73B0;&#x4E3B;&#x8981;&#x662F;&#x5229;&#x7528;&#x4E86;<span class="hljs-built_in">Object</span>.defineProperty&#x7684;&#x65B9;&#x6CD5;&#x91CC;&#x9762;&#x7684;setter &#x4E0E;getter&#x65B9;&#x6CD5;&#x7684;&#x89C2;&#x5BDF;&#x8005;&#x6A21;&#x5F0F;&#x6765;&#x5B9E;&#x73B0;&#x3002;&#x5728;&#x7EC4;&#x4EF6;&#x521D;&#x59CB;&#x5316;&#x65F6;&#x4F1A;&#x7ED9;&#x6BCF;&#x4E00;&#x4E2A;data&#x5C5E;&#x6027;&#x6CE8;&#x518C;getter&#x548C;setter&#xFF0C;&#x7136;&#x540E;&#x518D;<span class="hljs-keyword">new</span> &#x4E00;&#x4E2A;&#x81EA;&#x5DF1;&#x7684;Watcher&#x5BF9;&#x8C61;&#xFF0C;&#x6B64;&#x65F6;watcher&#x4F1A;&#x7ACB;&#x5373;&#x8C03;&#x7528;&#x7EC4;&#x4EF6;&#x7684;render&#x51FD;&#x6570;&#x53BB;&#x751F;&#x6210;&#x865A;&#x62DF;DOM&#x3002;&#x5728;&#x8C03;&#x7528;render&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x5C31;&#x4F1A;&#x9700;&#x8981;&#x7528;&#x5230;data&#x7684;&#x5C5E;&#x6027;&#x503C;&#xFF0C;&#x6B64;&#x65F6;&#x4F1A;&#x89E6;&#x53D1;getter&#x51FD;&#x6570;&#xFF0C;&#x5C06;&#x5F53;&#x524D;&#x7684;Watcher&#x51FD;&#x6570;&#x6CE8;&#x518C;&#x8FDB;sub&#x91CC;&#x3002;&#x5F53;data&#x5C5E;&#x6027;&#x53D1;&#x751F;&#x6539;&#x53D8;&#x4E4B;&#x540E;&#xFF0C;&#x5C31;&#x4F1A;&#x904D;&#x5386;sub&#x91CC;&#x6240;&#x6709;&#x7684;watcher&#x5BF9;&#x8C61;&#xFF0C;&#x901A;&#x77E5;&#x5B83;&#x4EEC;&#x53BB;&#x91CD;&#x65B0;&#x6E32;&#x67D3;&#x7EC4;&#x4EF6;&#x3002;

<span class="hljs-comment">// proxy&#x7684;&#x4F18;&#x52BF;&#x5982;&#x4E0B;&#xFF1A;</span>

<span class="hljs-built_in">Proxy</span> &#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x76D1;&#x542C;&#x5BF9;&#x8C61;&#x800C;&#x975E;&#x5C5E;&#x6027;&#xFF0C;&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x76D1;&#x542C;&#x6570;&#x7EC4;&#x7684;&#x53D8;&#x5316;&#xFF1B;
<span class="hljs-built_in">Proxy</span> &#x6709;&#x591A;&#x8FBE; <span class="hljs-number">13</span> &#x79CD;&#x62E6;&#x622A;&#x65B9;&#x6CD5;,&#x4E0D;&#x9650;&#x4E8E; apply&#x3001;ownKeys&#x3001;deleteProperty&#x3001;has &#x7B49;&#x7B49;&#x662F; <span class="hljs-built_in">Object</span>.defineProperty &#x4E0D;&#x5177;&#x5907;&#x7684;&#xFF1B;
<span class="hljs-built_in">Proxy</span> &#x8FD4;&#x56DE;&#x7684;&#x662F;&#x4E00;&#x4E2A;&#x65B0;&#x5BF9;&#x8C61;,&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x53EA;&#x64CD;&#x4F5C;&#x65B0;&#x7684;&#x5BF9;&#x8C61;&#x8FBE;&#x5230;&#x76EE;&#x7684;,&#x800C; <span class="hljs-built_in">Object</span>.defineProperty &#x53EA;&#x80FD;&#x904D;&#x5386;&#x5BF9;&#x8C61;&#x5C5E;&#x6027;&#x76F4;&#x63A5;&#x4FEE;&#x6539;&#xFF1B;


<span class="hljs-comment">// Object.defineProperty &#x7684;&#x4F18;&#x52BF;&#x5982;&#x4E0B;:</span>

&#x517C;&#x5BB9;&#x6027;&#x597D;&#xFF0C;&#x652F;&#x6301; IE9&#xFF0C;&#x800C; <span class="hljs-built_in">Proxy</span> &#x7684;&#x5B58;&#x5728;&#x6D4F;&#x89C8;&#x5668;&#x517C;&#x5BB9;&#x6027;&#x95EE;&#x9898;,&#x800C;&#x4E14;&#x65E0;&#x6CD5;&#x7528; polyfill(&#x57AB;&#x7247;)&#x6765;&#x5F25;&#x8865;
</code></pre>
<h5 id="9-&#x2605;&#x2605;&#x2605;&#x2605;-composition-api-&#x7684;&#x51FA;&#x73B0;&#x5E26;&#x6765;&#x54EA;&#x4E9B;&#x65B0;&#x7684;&#x5F00;&#x53D1;&#x4F53;&#x9A8C;&#xFF0C;&#x4E3A;&#x5565;&#x9700;&#x8981;&#x8FD9;&#x4E2A;&#xFF1F;"><a name="9-&#x2605;&#x2605;&#x2605;&#x2605;-composition-api-&#x7684;&#x51FA;&#x73B0;&#x5E26;&#x6765;&#x54EA;&#x4E9B;&#x65B0;&#x7684;&#x5F00;&#x53D1;&#x4F53;&#x9A8C;&#xFF0C;&#x4E3A;&#x5565;&#x9700;&#x8981;&#x8FD9;&#x4E2A;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#9-&#x2605;&#x2605;&#x2605;&#x2605;-composition-api-&#x7684;&#x51FA;&#x73B0;&#x5E26;&#x6765;&#x54EA;&#x4E9B;&#x65B0;&#x7684;&#x5F00;&#x53D1;&#x4F53;&#x9A8C;&#xFF0C;&#x4E3A;&#x5565;&#x9700;&#x8981;&#x8FD9;&#x4E2A;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="9-&#x2605;&#x2605;&#x2605;&#x2605;-composition-api-&#x7684;&#x51FA;&#x73B0;&#x5E26;&#x6765;&#x54EA;&#x4E9B;&#x65B0;&#x7684;&#x5F00;&#x53D1;&#x4F53;&#x9A8C;&#xFF0C;&#x4E3A;&#x5565;&#x9700;&#x8981;&#x8FD9;&#x4E2A;&#xFF1F;" class="plugin-anchor" href="#9-&#x2605;&#x2605;&#x2605;&#x2605;-composition-api-&#x7684;&#x51FA;&#x73B0;&#x5E26;&#x6765;&#x54EA;&#x4E9B;&#x65B0;&#x7684;&#x5F00;&#x53D1;&#x4F53;&#x9A8C;&#xFF0C;&#x4E3A;&#x5565;&#x9700;&#x8981;&#x8FD9;&#x4E2A;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>9. &#x2605;&#x2605;&#x2605;&#x2605; Composition API &#x7684;&#x51FA;&#x73B0;&#x5E26;&#x6765;&#x54EA;&#x4E9B;&#x65B0;&#x7684;&#x5F00;&#x53D1;&#x4F53;&#x9A8C;&#xFF0C;&#x4E3A;&#x5565;&#x9700;&#x8981;&#x8FD9;&#x4E2A;&#xFF1F;</h5>
<pre><code class="lang-JS"><span class="hljs-number">1</span>&#xFF1A;&#x5728;Compostion API &#x4E2D;&#x65F6;&#x6839;&#x636E;&#x903B;&#x8F91;&#x76F8;&#x5173;&#x7EC4;&#x7EC7;&#x4EE3;&#x7801;&#x7684;&#xFF0C;&#x63D0;&#x9AD8;&#x53EF;&#x8BFB;&#x6027;&#x548C;&#x53EF;&#x7EF4;&#x62A4;&#x6027;&#xFF0C;&#x7C7B;&#x4F3C;&#x4E8E;react&#x7684;hook&#x5199;&#x6CD5;&#x3002;
<span class="hljs-number">2</span>&#xFF1A;&#x66F4;&#x597D;&#x7684;&#x91CD;&#x7528;&#x903B;&#x8F91;&#x4EE3;&#x7801;&#xFF0C;&#x5728;Options API&#x4E2D;&#x901A;&#x8FC7;MIxins&#x91CD;&#x7528;&#x903B;&#x8F91;&#x4EE3;&#x7801;&#xFF0C;&#x5BB9;&#x6613;&#x53D1;&#x751F;&#x547D;&#x540D;&#x51B2;&#x7A81;&#x4E14;&#x5173;&#x7CFB;&#x4E0D;&#x6E05;&#x3002;
<span class="hljs-number">3</span>&#xFF1A;&#x89E3;&#x51B3;&#x5728;&#x751F;&#x547D;&#x5468;&#x671F;&#x51FD;&#x6570;&#x7ECF;&#x5E38;&#x5305;&#x542B;&#x4E0D;&#x76F8;&#x5173;&#x7684;&#x903B;&#x8F91;&#xFF0C;&#x4F46;&#x53C8;&#x4E0D;&#x5F97;&#x4E0D;&#x628A;&#x76F8;&#x5173;&#x903B;&#x8F91;&#x5206;&#x79BB;&#x5230;&#x4E86;&#x51E0;&#x4E2A;&#x4E0D;&#x540C;&#x65B9;&#x6CD5;&#x4E2D;&#x7684;&#x95EE;&#x9898;&#xFF0C;&#x5982;&#x5728;mounted&#x4E2D;&#x8BBE;&#x7F6E;&#x5B9A;&#x65F6;&#x5668;&#xFF0C;&#x4F46;&#x9700;&#x8981;&#x5728;destroyed&#x4E2D;&#x6765;&#x6E05;&#x9664;&#x5B9A;&#x65F6;&#x5668;&#xFF0C;&#x5C06;&#x540C;&#x4E00;&#x529F;&#x80FD;&#x7684;&#x4EE3;&#x7801;&#x62C6;&#x5206;&#x5230;&#x4E0D;&#x540C;&#x7684;&#x4F4D;&#x7F6E;&#xFF0C;&#x9020;&#x6210;&#x540E;&#x671F;&#x4EE3;&#x7801;&#x7EF4;&#x62A4;&#x7684;&#x56F0;&#x96BE;&#x3002;
</code></pre>
<h5 id="10-&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x60C5;&#x51B5;&#x4E0B;&#x4F7F;&#x7528;-vuex"><a name="10-&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x60C5;&#x51B5;&#x4E0B;&#x4F7F;&#x7528;-vuex" class="anchor-navigation-ex-anchor" href="#10-&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x60C5;&#x51B5;&#x4E0B;&#x4F7F;&#x7528;-vuex"><i class="fa fa-link" aria-hidden="true"></i></a><a name="10-&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x60C5;&#x51B5;&#x4E0B;&#x4F7F;&#x7528;-vuex" class="plugin-anchor" href="#10-&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x60C5;&#x51B5;&#x4E0B;&#x4F7F;&#x7528;-vuex"><i class="fa fa-link" aria-hidden="true"></i></a>10. &#x2605;&#x2605;&#x2605; &#x4EC0;&#x4E48;&#x60C5;&#x51B5;&#x4E0B;&#x4F7F;&#x7528; Vuex</h5>
<pre><code class="lang-JS">&#x5982;&#x679C;&#x5E94;&#x7528;&#x591F;&#x7B80;&#x5355;&#xFF0C;&#x6700;&#x597D;&#x4E0D;&#x8981;&#x4F7F;&#x7528; Vuex&#xFF0C;&#x4E00;&#x4E2A;&#x7B80;&#x5355;&#x7684; store &#x6A21;&#x5F0F;&#x5373;&#x53EF;&#xFF0C;&#x9700;&#x8981;&#x6784;&#x5EFA;&#x4E00;&#x4E2A;&#x4E2D;&#x5927;&#x578B;&#x5355;&#x9875;&#x5E94;&#x7528;&#x65F6;&#xFF0C;&#x4F7F;&#x7528;Vuex&#x80FD;&#x66F4;&#x597D;&#x5730;&#x5728;&#x7EC4;&#x4EF6;&#x5916;&#x90E8;&#x7BA1;&#x7406;&#x72B6;&#x6001;
</code></pre>
<h5 id="11-&#x2605;&#x2605;&#x2605;-vuex&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x4FEE;&#x6539;state&#x7684;&#x503C;&#x5417;&#xFF1F;"><a name="11-&#x2605;&#x2605;&#x2605;-vuex&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x4FEE;&#x6539;state&#x7684;&#x503C;&#x5417;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#11-&#x2605;&#x2605;&#x2605;-vuex&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x4FEE;&#x6539;state&#x7684;&#x503C;&#x5417;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="11-&#x2605;&#x2605;&#x2605;-vuex&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x4FEE;&#x6539;state&#x7684;&#x503C;&#x5417;&#xFF1F;" class="plugin-anchor" href="#11-&#x2605;&#x2605;&#x2605;-vuex&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x4FEE;&#x6539;state&#x7684;&#x503C;&#x5417;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>11. &#x2605;&#x2605;&#x2605; Vuex&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x4FEE;&#x6539;state&#x7684;&#x503C;&#x5417;&#xFF1F;</h5>
<pre><code class="lang-JS">&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x4FEE;&#x6539;&#xFF0C;&#x4F46;&#x662F;&#x6781;&#x5176;&#x4E0D;&#x63A8;&#x8350;&#xFF0C;state&#x7684;&#x4FEE;&#x6539;&#x5FC5;&#x987B;&#x5728;mutation&#x6765;&#x4FEE;&#x6539;&#xFF0C;&#x5426;&#x5219;&#x65E0;&#x6CD5;&#x88AB;devtool&#x6240;&#x76D1;&#x6D4B;&#xFF0C;&#x65E0;&#x6CD5;&#x76D1;&#x6D4B;&#x6570;&#x636E;&#x7684;&#x6765;&#x6E90;&#xFF0C;&#x65E0;&#x6CD5;&#x4FDD;&#x5B58;&#x72B6;&#x6001;&#x5FEB;&#x7167;&#xFF0C;&#x4E5F;&#x5C31;&#x65E0;&#x6CD5;&#x5B9E;&#x73B0;&#x65F6;&#x95F4;&#x6F2B;&#x6E38;/&#x56DE;&#x6EDA;&#x4E4B;&#x7C7B;&#x7684;&#x64CD;&#x4F5C;&#x3002;
</code></pre>
<h5 id="12-&#x2605;&#x2605;&#x2605;&#x2605;-&#x4E3A;&#x4EC0;&#x4E48;vuex&#x7684;mutation&#x4E0D;&#x80FD;&#x505A;&#x5F02;&#x6B65;&#x64CD;&#x4F5C;"><a name="12-&#x2605;&#x2605;&#x2605;&#x2605;-&#x4E3A;&#x4EC0;&#x4E48;vuex&#x7684;mutation&#x4E0D;&#x80FD;&#x505A;&#x5F02;&#x6B65;&#x64CD;&#x4F5C;" class="anchor-navigation-ex-anchor" href="#12-&#x2605;&#x2605;&#x2605;&#x2605;-&#x4E3A;&#x4EC0;&#x4E48;vuex&#x7684;mutation&#x4E0D;&#x80FD;&#x505A;&#x5F02;&#x6B65;&#x64CD;&#x4F5C;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="12-&#x2605;&#x2605;&#x2605;&#x2605;-&#x4E3A;&#x4EC0;&#x4E48;vuex&#x7684;mutation&#x4E0D;&#x80FD;&#x505A;&#x5F02;&#x6B65;&#x64CD;&#x4F5C;" class="plugin-anchor" href="#12-&#x2605;&#x2605;&#x2605;&#x2605;-&#x4E3A;&#x4EC0;&#x4E48;vuex&#x7684;mutation&#x4E0D;&#x80FD;&#x505A;&#x5F02;&#x6B65;&#x64CD;&#x4F5C;"><i class="fa fa-link" aria-hidden="true"></i></a>12. &#x2605;&#x2605;&#x2605;&#x2605; &#x4E3A;&#x4EC0;&#x4E48;Vuex&#x7684;mutation&#x4E0D;&#x80FD;&#x505A;&#x5F02;&#x6B65;&#x64CD;&#x4F5C;</h5>
<pre><code class="lang-JS">Vuex&#x4E2D;&#x6240;&#x6709;&#x7684;&#x72B6;&#x6001;&#x66F4;&#x65B0;&#x7684;&#x552F;&#x4E00;&#x9014;&#x5F84;&#x90FD;&#x662F;mutation&#xFF0C;&#x5F02;&#x6B65;&#x64CD;&#x4F5C;&#x901A;&#x8FC7; Action &#x6765;&#x63D0;&#x4EA4; mutation&#x5B9E;&#x73B0;&#xFF0C;&#x8FD9;&#x6837;&#x4F7F;&#x5F97;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x65B9;&#x4FBF;&#x5730;&#x8DDF;&#x8E2A;&#x6BCF;&#x4E00;&#x4E2A;&#x72B6;&#x6001;&#x7684;&#x53D8;&#x5316;&#xFF0C;&#x4ECE;&#x800C;&#x8BA9;&#x6211;&#x4EEC;&#x80FD;&#x591F;&#x5B9E;&#x73B0;&#x4E00;&#x4E9B;&#x5DE5;&#x5177;&#x5E2E;&#x52A9;&#x6211;&#x4EEC;&#x66F4;&#x597D;&#x5730;&#x4E86;&#x89E3;&#x6211;&#x4EEC;&#x7684;&#x5E94;&#x7528;&#x3002;&#x6BCF;&#x4E2A;mutation&#x6267;&#x884C;&#x5B8C;&#x6210;&#x540E;&#x90FD;&#x4F1A;&#x5BF9;&#x5E94;&#x5230;&#x4E00;&#x4E2A;&#x65B0;&#x7684;&#x72B6;&#x6001;&#x53D8;&#x66F4;&#xFF0C;&#x8FD9;&#x6837;devtools&#x5C31;&#x53EF;&#x4EE5;&#x6253;&#x4E2A;&#x5FEB;&#x7167;&#x5B58;&#x4E0B;&#x6765;&#xFF0C;&#x5426;&#x5219;&#x65E0;&#x6CD5;&#x88AB;devtools&#x6240;&#x76D1;&#x6D4B;&#x3002;&#x5982;&#x679C;mutation&#x652F;&#x6301;&#x5F02;&#x6B65;&#x64CD;&#x4F5C;&#xFF0C;&#x5C31;&#x6CA1;&#x6709;&#x529E;&#x6CD5;&#x77E5;&#x9053;&#x72B6;&#x6001;&#x662F;&#x4F55;&#x65F6;&#x66F4;&#x65B0;&#x7684;&#xFF0C;&#x65E0;&#x6CD5;&#x5F88;&#x597D;&#x7684;&#x8FDB;&#x884C;&#x72B6;&#x6001;&#x7684;&#x8FFD;&#x8E2A;&#xFF0C;&#x7ED9;&#x8C03;&#x8BD5;&#x5E26;&#x6765;&#x56F0;&#x96BE;&#x3002;
</code></pre>
<h5 id="13-&#x2605;&#x2605;&#x2605;-v-model&#x548C;vuex&#x6709;&#x51B2;&#x7A81;&#x5417;&#xFF1F;"><a name="13-&#x2605;&#x2605;&#x2605;-v-model&#x548C;vuex&#x6709;&#x51B2;&#x7A81;&#x5417;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#13-&#x2605;&#x2605;&#x2605;-v-model&#x548C;vuex&#x6709;&#x51B2;&#x7A81;&#x5417;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="13-&#x2605;&#x2605;&#x2605;-v-model&#x548C;vuex&#x6709;&#x51B2;&#x7A81;&#x5417;&#xFF1F;" class="plugin-anchor" href="#13-&#x2605;&#x2605;&#x2605;-v-model&#x548C;vuex&#x6709;&#x51B2;&#x7A81;&#x5417;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>13. &#x2605;&#x2605;&#x2605; v-model&#x548C;vuex&#x6709;&#x51B2;&#x7A81;&#x5417;&#xFF1F;</h5>
<pre><code class="lang-JS"><span class="hljs-comment">// &#x7B54;&#x6848;&#xFF1A;</span>
</code></pre>
<h5 id="14-&#x2605;&#x2605;&#x2605;-&#x89E3;&#x91CA;&#x5355;&#x5411;&#x6570;&#x636E;&#x6D41;&#x548C;&#x53CC;&#x5411;&#x6570;&#x636E;&#x7ED1;&#x5B9A;"><a name="14-&#x2605;&#x2605;&#x2605;-&#x89E3;&#x91CA;&#x5355;&#x5411;&#x6570;&#x636E;&#x6D41;&#x548C;&#x53CC;&#x5411;&#x6570;&#x636E;&#x7ED1;&#x5B9A;" class="anchor-navigation-ex-anchor" href="#14-&#x2605;&#x2605;&#x2605;-&#x89E3;&#x91CA;&#x5355;&#x5411;&#x6570;&#x636E;&#x6D41;&#x548C;&#x53CC;&#x5411;&#x6570;&#x636E;&#x7ED1;&#x5B9A;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="14-&#x2605;&#x2605;&#x2605;-&#x89E3;&#x91CA;&#x5355;&#x5411;&#x6570;&#x636E;&#x6D41;&#x548C;&#x53CC;&#x5411;&#x6570;&#x636E;&#x7ED1;&#x5B9A;" class="plugin-anchor" href="#14-&#x2605;&#x2605;&#x2605;-&#x89E3;&#x91CA;&#x5355;&#x5411;&#x6570;&#x636E;&#x6D41;&#x548C;&#x53CC;&#x5411;&#x6570;&#x636E;&#x7ED1;&#x5B9A;"><i class="fa fa-link" aria-hidden="true"></i></a>14. &#x2605;&#x2605;&#x2605; &#x89E3;&#x91CA;&#x5355;&#x5411;&#x6570;&#x636E;&#x6D41;&#x548C;&#x53CC;&#x5411;&#x6570;&#x636E;&#x7ED1;&#x5B9A;</h5>
<pre><code class="lang-JS">&#x5BF9;&#x4E8E; Vue &#x6765;&#x8BF4;&#xFF0C;&#x7EC4;&#x4EF6;&#x4E4B;&#x95F4;&#x7684;&#x6570;&#x636E;&#x4F20;&#x9012;&#x5177;&#x6709;&#x5355;&#x5411;&#x6570;&#x636E;&#x6D41;&#x8FD9;&#x6837;&#x7684;&#x7279;&#x6027;&#x79F0;&#x4E3A;&#x5355;&#x5411;&#x6570;&#x636E;&#x6D41;&#xFF0C;&#x5355;&#x5411;&#x6570;&#x636E;&#x6D41;&#xFF08;Unidirectional data flow&#xFF09;&#x65B9;&#x5F0F;&#x4F7F;&#x7528;&#x4E00;&#x4E2A;&#x4E0A;&#x4F20;&#x6570;&#x636E;&#x6D41;&#x548C;&#x4E00;&#x4E2A;&#x4E0B;&#x4F20;&#x6570;&#x636E;&#x6D41;&#x8FDB;&#x884C;&#x53CC;&#x5411;&#x6570;&#x636E;&#x901A;&#x4FE1;&#xFF0C;&#x4E24;&#x4E2A;&#x6570;&#x636E;&#x6D41;&#x4E4B;&#x95F4;&#x76F8;&#x4E92;&#x72EC;&#x7ACB;&#xFF0C;&#x5355;&#x5411;&#x6570;&#x636E;&#x6D41;&#x6307;&#x53EA;&#x80FD;&#x4ECE;&#x4E00;&#x4E2A;&#x65B9;&#x5411;&#x6765;&#x4FEE;&#x6539;&#x72B6;&#x6001;&#x3002;

&#x800C;&#x53CC;&#x5411;&#x6570;&#x636E;&#x7ED1;&#x5B9A;&#x5373;&#x4E3A;&#x5F53;&#x6570;&#x636E;&#x53D1;&#x751F;&#x53D8;&#x5316;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x89C6;&#x56FE;&#x4E5F;&#x5C31;&#x53D1;&#x751F;&#x53D8;&#x5316;&#xFF0C;&#x5F53;&#x89C6;&#x56FE;&#x53D1;&#x751F;&#x53D8;&#x5316;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x6570;&#x636E;&#x4E5F;&#x4F1A;&#x8DDF;&#x7740;&#x540C;&#x6B65;&#x53D8;&#x5316;&#xFF0C;&#x4E24;&#x4E2A;&#x6570;&#x636E;&#x6D41;&#x4E4B;&#x95F4;&#x4E92;&#x4E3A;&#x5F71;&#x54CD;&#x3002;
</code></pre>
<h5 id="15-&#x2605;&#x2605;-vue-&#x5982;&#x4F55;&#x53BB;&#x9664;url&#x4E2D;&#x7684;-"><a name="15-&#x2605;&#x2605;-vue-&#x5982;&#x4F55;&#x53BB;&#x9664;url&#x4E2D;&#x7684;-" class="anchor-navigation-ex-anchor" href="#15-&#x2605;&#x2605;-vue-&#x5982;&#x4F55;&#x53BB;&#x9664;url&#x4E2D;&#x7684;-"><i class="fa fa-link" aria-hidden="true"></i></a><a name="15-&#x2605;&#x2605;-vue-&#x5982;&#x4F55;&#x53BB;&#x9664;url&#x4E2D;&#x7684;-" class="plugin-anchor" href="#15-&#x2605;&#x2605;-vue-&#x5982;&#x4F55;&#x53BB;&#x9664;url&#x4E2D;&#x7684;-"><i class="fa fa-link" aria-hidden="true"></i></a>15. &#x2605;&#x2605; Vue &#x5982;&#x4F55;&#x53BB;&#x9664;url&#x4E2D;&#x7684; <code>#</code></h5>
<pre><code class="lang-JS">&#x5C06;&#x8DEF;&#x7531;&#x6A21;&#x5F0F;&#x6539;&#x4E3A;history
</code></pre>
<h5 id="16-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue-router-&#x8DEF;&#x7531;&#x5B9E;&#x73B0;&#x539F;&#x7406;"><a name="16-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue-router-&#x8DEF;&#x7531;&#x5B9E;&#x73B0;&#x539F;&#x7406;" class="anchor-navigation-ex-anchor" href="#16-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue-router-&#x8DEF;&#x7531;&#x5B9E;&#x73B0;&#x539F;&#x7406;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="16-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue-router-&#x8DEF;&#x7531;&#x5B9E;&#x73B0;&#x539F;&#x7406;" class="plugin-anchor" href="#16-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue-router-&#x8DEF;&#x7531;&#x5B9E;&#x73B0;&#x539F;&#x7406;"><i class="fa fa-link" aria-hidden="true"></i></a>16. &#x2605;&#x2605;&#x2605;&#x2605;&#x2605; vue-router &#x8DEF;&#x7531;&#x5B9E;&#x73B0;&#x539F;&#x7406;</h5>
<pre><code class="lang-JS">

</code></pre>
<h5 id="17-&#x2605;&#x2605;&#x2605;-route-&#x548C;-router-&#x7684;&#x533A;&#x522B;"><a name="17-&#x2605;&#x2605;&#x2605;-route-&#x548C;-router-&#x7684;&#x533A;&#x522B;" class="anchor-navigation-ex-anchor" href="#17-&#x2605;&#x2605;&#x2605;-route-&#x548C;-router-&#x7684;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="17-&#x2605;&#x2605;&#x2605;-route-&#x548C;-router-&#x7684;&#x533A;&#x522B;" class="plugin-anchor" href="#17-&#x2605;&#x2605;&#x2605;-route-&#x548C;-router-&#x7684;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a>17. &#x2605;&#x2605;&#x2605; $route &#x548C; $router &#x7684;&#x533A;&#x522B;</h5>
<pre><code class="lang-JS">$route&#x7528;&#x6765;&#x83B7;&#x53D6;&#x8DEF;&#x7531;&#x7684;&#x4FE1;&#x606F;&#x7684;&#xFF0C;&#x5B83;&#x662F;&#x8DEF;&#x7531;&#x4FE1;&#x606F;&#x7684;&#x4E00;&#x4E2A;&#x5BF9;&#x8C61;&#xFF0C;&#x91CC;&#x9762;&#x5305;&#x542B;&#x8DEF;&#x7531;&#x7684;&#x4E00;&#x4E9B;&#x57FA;&#x672C;&#x4FE1;&#x606F;&#xFF0C;&#x5305;&#x62EC;name&#x3001;meta&#x3001;path&#x3001;hash&#x3001;query&#x3001;params&#x3001;fullPath&#x3001;matched&#x3001;redirectedFrom&#x7B49;&#x3002;&#x800C;$router&#x4E3B;&#x8981;&#x662F;&#x7528;&#x6765;&#x64CD;&#x4F5C;&#x8DEF;&#x7531;&#x7684;&#xFF0C;&#x5B83;&#x662F;VueRouter&#x7684;&#x5B9E;&#x4F8B;&#xFF0C;&#x5305;&#x542B;&#x4E86;&#x4E00;&#x4E9B;&#x8DEF;&#x7531;&#x7684;&#x8DF3;&#x8F6C;&#x65B9;&#x6CD5;&#xFF0C;&#x94A9;&#x5B50;&#x51FD;&#x6570;&#x7B49;
</code></pre>
<h5 id="18-&#x2605;&#x2605;-&#x5BF9;&#x6BD4;-jquery&#xFF0C;vue-&#x6709;&#x4EC0;&#x4E48;&#x4E0D;&#x540C;"><a name="18-&#x2605;&#x2605;-&#x5BF9;&#x6BD4;-jquery&#xFF0C;vue-&#x6709;&#x4EC0;&#x4E48;&#x4E0D;&#x540C;" class="anchor-navigation-ex-anchor" href="#18-&#x2605;&#x2605;-&#x5BF9;&#x6BD4;-jquery&#xFF0C;vue-&#x6709;&#x4EC0;&#x4E48;&#x4E0D;&#x540C;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="18-&#x2605;&#x2605;-&#x5BF9;&#x6BD4;-jquery&#xFF0C;vue-&#x6709;&#x4EC0;&#x4E48;&#x4E0D;&#x540C;" class="plugin-anchor" href="#18-&#x2605;&#x2605;-&#x5BF9;&#x6BD4;-jquery&#xFF0C;vue-&#x6709;&#x4EC0;&#x4E48;&#x4E0D;&#x540C;"><i class="fa fa-link" aria-hidden="true"></i></a>18. &#x2605;&#x2605; &#x5BF9;&#x6BD4; jQuery&#xFF0C;Vue &#x6709;&#x4EC0;&#x4E48;&#x4E0D;&#x540C;</h5>
<pre><code class="lang-JS">jQuery &#x4E13;&#x6CE8;&#x89C6;&#x56FE;&#x5C42;&#xFF0C;&#x901A;&#x8FC7;&#x76F4;&#x63A5;&#x64CD;&#x4F5C; DOM &#x53BB;&#x5B9E;&#x73B0;&#x9875;&#x9762;&#x7684;&#x4E00;&#x4E9B;&#x903B;&#x8F91;&#x6E32;&#x67D3;&#xFF1B;Vue &#x4E13;&#x6CE8;&#x4E8E;&#x6570;&#x636E;&#x5C42;&#xFF0C;&#x901A;&#x8FC7;&#x6570;&#x636E;&#x7684;&#x53CC;&#x5411;&#x7ED1;&#x5B9A;&#xFF0C;&#x6700;&#x7EC8;&#x8868;&#x73B0;&#x5728; DOM &#x5C42;&#x9762;&#xFF0C;&#x51CF;&#x5C11;&#x4E86; DOM &#x64CD;&#x4F5C;&#x3002;Vue &#x4F7F;&#x7528;&#x4E86;&#x7EC4;&#x4EF6;&#x5316;&#x601D;&#x60F3;&#xFF0C;&#x4F7F;&#x5F97;&#x9879;&#x76EE;&#x5B50;&#x96C6;&#x804C;&#x8D23;&#x6E05;&#x6670;&#xFF0C;&#x63D0;&#x9AD8;&#x4E86;&#x5F00;&#x53D1;&#x6548;&#x7387;&#xFF0C;&#x65B9;&#x4FBF;&#x91CD;&#x590D;&#x5229;&#x7528;&#xFF0C;&#x4FBF;&#x4E8E;&#x534F;&#x540C;&#x5F00;&#x53D1;
</code></pre>
<h5 id="19-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;&#x600E;&#x4E48;&#x81EA;&#x5B9A;&#x4E49;&#x6307;&#x4EE4;"><a name="19-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;&#x600E;&#x4E48;&#x81EA;&#x5B9A;&#x4E49;&#x6307;&#x4EE4;" class="anchor-navigation-ex-anchor" href="#19-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;&#x600E;&#x4E48;&#x81EA;&#x5B9A;&#x4E49;&#x6307;&#x4EE4;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="19-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;&#x600E;&#x4E48;&#x81EA;&#x5B9A;&#x4E49;&#x6307;&#x4EE4;" class="plugin-anchor" href="#19-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;&#x600E;&#x4E48;&#x81EA;&#x5B9A;&#x4E49;&#x6307;&#x4EE4;"><i class="fa fa-link" aria-hidden="true"></i></a>19. &#x2605;&#x2605;&#x2605; Vue &#x4E2D;&#x600E;&#x4E48;&#x81EA;&#x5B9A;&#x4E49;&#x6307;&#x4EE4;</h5>
<pre><code class="lang-JS">&#x901A;&#x8FC7;directive&#x6765;&#x81EA;&#x5B9A;&#x4E49;&#x6307;&#x4EE4;&#xFF0C;&#x81EA;&#x5B9A;&#x4E49;&#x6307;&#x4EE4;&#x5206;&#x4E3A;&#x5168;&#x5C40;&#x6307;&#x4EE4;&#x548C;&#x5C40;&#x90E8;&#x6307;&#x4EE4;&#xFF0C;&#x81EA;&#x5B9A;&#x4E49;&#x6307;&#x4EE4;&#x4E5F;&#x6709;&#x51E0;&#x4E2A;&#x7684;&#x94A9;&#x5B50;&#x51FD;&#x6570;&#xFF0C;&#x5E38;&#x7528;&#x7684;&#x6709;bind&#x548C;update&#xFF0C;&#x5F53; bind &#x548C; update &#x65F6;&#x89E6;&#x53D1;&#x76F8;&#x540C;&#x884C;&#x4E3A;&#xFF0C;&#x800C;&#x4E0D;&#x5173;&#x5FC3;&#x5176;&#x5B83;&#x7684;&#x94A9;&#x5B50;&#x65F6;&#x53EF;&#x4EE5;&#x7B80;&#x5199;&#x3002;&#x4E00;&#x4E2A;&#x8868;&#x8FBE;&#x5F0F;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x591A;&#x4E2A;&#x8FC7;&#x6EE4;&#x5668;&#x3002;&#x8FC7;&#x6EE4;&#x5668;&#x4E4B;&#x95F4;&#x9700;&#x8981;&#x7528;&#x7BA1;&#x9053;&#x7B26;&#x201C;|&#x201D;&#x9694;&#x5F00;&#x3002;&#x5176;&#x6267;&#x884C;&#x987A;&#x5E8F;&#x4ECE;&#x5DE6;&#x5F80;&#x53F3;&#x3002;
</code></pre>
<h5 id="20-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;&#x600E;&#x4E48;&#x81EA;&#x5B9A;&#x4E49;&#x8FC7;&#x6EE4;&#x5668;"><a name="20-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;&#x600E;&#x4E48;&#x81EA;&#x5B9A;&#x4E49;&#x8FC7;&#x6EE4;&#x5668;" class="anchor-navigation-ex-anchor" href="#20-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;&#x600E;&#x4E48;&#x81EA;&#x5B9A;&#x4E49;&#x8FC7;&#x6EE4;&#x5668;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="20-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;&#x600E;&#x4E48;&#x81EA;&#x5B9A;&#x4E49;&#x8FC7;&#x6EE4;&#x5668;" class="plugin-anchor" href="#20-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;&#x600E;&#x4E48;&#x81EA;&#x5B9A;&#x4E49;&#x8FC7;&#x6EE4;&#x5668;"><i class="fa fa-link" aria-hidden="true"></i></a>20. &#x2605;&#x2605;&#x2605; Vue &#x4E2D;&#x600E;&#x4E48;&#x81EA;&#x5B9A;&#x4E49;&#x8FC7;&#x6EE4;&#x5668;</h5>
<pre><code class="lang-JS">&#x901A;&#x8FC7;filter&#x6765;&#x5B9A;&#x4E49;&#x8FC7;&#x6EE4;&#x5668;&#xFF0C;&#x8FC7;&#x6EE4;&#x5668;&#x5206;&#x4E3A;&#x5168;&#x5C40;&#x548C;&#x5C40;&#x90E8;&#x8FC7;&#x6EE4;&#x5668;&#xFF0C;&#x8FC7;&#x6EE4;&#x5668;&#x7684;&#x4E3B;&#x4F53;&#x4E3A;&#x4E00;&#x4E2A;&#x666E;&#x901A;&#x7684;&#x51FD;&#x6570;&#xFF0C;&#x6765;&#x5BF9;&#x6570;&#x636E;&#x8FDB;&#x884C;&#x5904;&#x7406;&#xFF0C;&#x53EF;&#x4EE5;&#x4F20;&#x9012;&#x53C2;&#x6570;&#x3002;&#x5F53;&#x6709;&#x5C40;&#x90E8;&#x548C;&#x5168;&#x5C40;&#x4E24;&#x4E2A;&#x540D;&#x79F0;&#x76F8;&#x540C;&#x7684;&#x8FC7;&#x6EE4;&#x5668;&#x65F6;&#x5019;&#xFF0C;&#x4F1A;&#x4EE5;&#x5C31;&#x8FD1;&#x539F;&#x5219;&#x8FDB;&#x884C;&#x8C03;&#x7528;&#xFF0C;&#x5373;&#xFF1A;&#x5C40;&#x90E8;&#x8FC7;&#x6EE4;&#x5668;&#x4F18;&#x5148;&#x4E8E;&#x5168;&#x5C40;&#x8FC7;&#x6EE4;&#x5668;&#x88AB;&#x8C03;&#x7528;&#x3002;
</code></pre>
<h5 id="21-&#x2605;&#x2605;&#x2605;-vue-&#x7B49;&#x5355;&#x9875;&#x9762;&#x5E94;&#x7528;&#x7684;&#x4F18;&#x7F3A;&#x70B9;"><a name="21-&#x2605;&#x2605;&#x2605;-vue-&#x7B49;&#x5355;&#x9875;&#x9762;&#x5E94;&#x7528;&#x7684;&#x4F18;&#x7F3A;&#x70B9;" class="anchor-navigation-ex-anchor" href="#21-&#x2605;&#x2605;&#x2605;-vue-&#x7B49;&#x5355;&#x9875;&#x9762;&#x5E94;&#x7528;&#x7684;&#x4F18;&#x7F3A;&#x70B9;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="21-&#x2605;&#x2605;&#x2605;-vue-&#x7B49;&#x5355;&#x9875;&#x9762;&#x5E94;&#x7528;&#x7684;&#x4F18;&#x7F3A;&#x70B9;" class="plugin-anchor" href="#21-&#x2605;&#x2605;&#x2605;-vue-&#x7B49;&#x5355;&#x9875;&#x9762;&#x5E94;&#x7528;&#x7684;&#x4F18;&#x7F3A;&#x70B9;"><i class="fa fa-link" aria-hidden="true"></i></a>21. &#x2605;&#x2605;&#x2605; Vue &#x7B49;&#x5355;&#x9875;&#x9762;&#x5E94;&#x7528;&#x7684;&#x4F18;&#x7F3A;&#x70B9;</h5>
<pre><code class="lang-JS"><span class="hljs-comment">// &#x4F18;&#x70B9;</span>
<span class="hljs-number">1</span>&#x5355;&#x9875;&#x5E94;&#x7528;&#x7684;&#x5185;&#x5BB9;&#x7684;&#x6539;&#x53D8;&#x4E0D;&#x9700;&#x8981;&#x91CD;&#x65B0;&#x52A0;&#x8F7D;&#x6574;&#x4E2A;&#x9875;&#x9762;&#xFF0C;web&#x5E94;&#x7528;&#x66F4;&#x5177;&#x54CD;&#x5E94;&#x6027;&#x548C;&#x66F4;&#x4EE4;&#x4EBA;&#x7740;&#x8FF7;&#x3002;

<span class="hljs-number">2</span>&#x3001;&#x5355;&#x9875;&#x5E94;&#x7528;&#x6CA1;&#x6709;&#x9875;&#x9762;&#x4E4B;&#x95F4;&#x7684;&#x5207;&#x6362;&#xFF0C;&#x5C31;&#x4E0D;&#x4F1A;&#x51FA;&#x73B0;&#x201C;&#x767D;&#x5C4F;&#x73B0;&#x8C61;&#x201D;,&#x4E5F;&#x4E0D;&#x4F1A;&#x51FA;&#x73B0;&#x5047;&#x6B7B;&#x5E76;&#x6709;&#x201C;&#x95EA;&#x70C1;&#x201D;&#x73B0;&#x8C61;

<span class="hljs-number">3</span>&#x3001;&#x5355;&#x9875;&#x5E94;&#x7528;&#x76F8;&#x5BF9;&#x670D;&#x52A1;&#x5668;&#x538B;&#x529B;&#x5C0F;&#xFF0C;&#x670D;&#x52A1;&#x5668;&#x53EA;&#x7528;&#x51FA;&#x6570;&#x636E;&#x5C31;&#x53EF;&#x4EE5;&#xFF0C;&#x4E0D;&#x7528;&#x7BA1;&#x5C55;&#x793A;&#x903B;&#x8F91;&#x548C;&#x9875;&#x9762;&#x5408;&#x6210;&#xFF0C;&#x541E;&#x5410;&#x80FD;&#x529B;&#x4F1A;&#x63D0;&#x9AD8;&#x51E0;&#x500D;&#x3002;

<span class="hljs-number">4</span>&#x3001;&#x826F;&#x597D;&#x7684;&#x524D;&#x540E;&#x7AEF;&#x5206;&#x79BB;&#x3002;&#x540E;&#x7AEF;&#x4E0D;&#x518D;&#x8D1F;&#x8D23;&#x6A21;&#x677F;&#x6E32;&#x67D3;&#x3001;&#x8F93;&#x51FA;&#x9875;&#x9762;&#x5DE5;&#x4F5C;&#xFF0C;&#x540E;&#x7AEF;API&#x901A;&#x7528;&#x5316;&#xFF0C;&#x5373;&#x540C;&#x4E00;&#x5957;&#x540E;&#x7AEF;&#x7A0B;&#x5E8F;&#x4EE3;&#x7801;&#xFF0C;&#x4E0D;&#x7528;&#x4FEE;&#x6539;&#x5C31;&#x53EF;&#x4EE5;&#x7528;&#x4E8E;Web&#x754C;&#x9762;&#x3001;&#x624B;&#x673A;&#x3001;&#x5E73;&#x677F;&#x7B49;&#x591A;&#x79CD;&#x5BA2;&#x6237;&#x7AEF;&#x3002;

<span class="hljs-comment">// &#x7F3A;&#x70B9;</span>
<span class="hljs-number">1</span>&#x3001;&#x9996;&#x6B21;&#x52A0;&#x8F7D;&#x8017;&#x65F6;&#x6BD4;&#x8F83;&#x591A;&#x3002;

<span class="hljs-number">2</span>&#x3001;SEO&#x95EE;&#x9898;&#xFF0C;&#x4E0D;&#x5229;&#x4E8E;&#x767E;&#x5EA6;&#xFF0C;<span class="hljs-number">360</span>&#x7B49;&#x641C;&#x7D22;&#x5F15;&#x64CE;&#x6536;&#x5F55;&#x3002;

<span class="hljs-number">3</span>&#x3001;&#x5BB9;&#x6613;&#x9020;&#x6210;Css&#x547D;&#x540D;&#x51B2;&#x7A81;&#x3002;

<span class="hljs-number">4</span>&#x3001;&#x524D;&#x8FDB;&#x3001;&#x540E;&#x9000;&#x3001;&#x5730;&#x5740;&#x680F;&#x3001;&#x4E66;&#x7B7E;&#x7B49;&#xFF0C;&#x90FD;&#x9700;&#x8981;&#x7A0B;&#x5E8F;&#x8FDB;&#x884C;&#x7BA1;&#x7406;&#xFF0C;&#x9875;&#x9762;&#x7684;&#x590D;&#x6742;&#x5EA6;&#x5F88;&#x9AD8;&#xFF0C;&#x9700;&#x8981;&#x4E00;&#x5B9A;&#x7684;&#x6280;&#x80FD;&#x6C34;&#x5E73;&#x548C;&#x5F00;&#x53D1;&#x6210;&#x672C;&#x9AD8;&#x3002;
</code></pre>
<h5 id="22-&#x2605;&#x2605;&#x2605;-vue-router-&#x4F7F;&#x7528;params&#x4E0E;query&#x4F20;&#x53C2;&#x6709;&#x4EC0;&#x4E48;&#x533A;&#x522B;"><a name="22-&#x2605;&#x2605;&#x2605;-vue-router-&#x4F7F;&#x7528;params&#x4E0E;query&#x4F20;&#x53C2;&#x6709;&#x4EC0;&#x4E48;&#x533A;&#x522B;" class="anchor-navigation-ex-anchor" href="#22-&#x2605;&#x2605;&#x2605;-vue-router-&#x4F7F;&#x7528;params&#x4E0E;query&#x4F20;&#x53C2;&#x6709;&#x4EC0;&#x4E48;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="22-&#x2605;&#x2605;&#x2605;-vue-router-&#x4F7F;&#x7528;params&#x4E0E;query&#x4F20;&#x53C2;&#x6709;&#x4EC0;&#x4E48;&#x533A;&#x522B;" class="plugin-anchor" href="#22-&#x2605;&#x2605;&#x2605;-vue-router-&#x4F7F;&#x7528;params&#x4E0E;query&#x4F20;&#x53C2;&#x6709;&#x4EC0;&#x4E48;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a>22. &#x2605;&#x2605;&#x2605; Vue-router &#x4F7F;&#x7528;params&#x4E0E;query&#x4F20;&#x53C2;&#x6709;&#x4EC0;&#x4E48;&#x533A;&#x522B;</h5>
<pre><code class="lang-JS"><span class="hljs-comment">// &#x7528;&#x6CD5;&#x4E0A;</span>
<span class="hljs-number">1</span>&#xFF1A;query&#x8981;&#x7528;path&#x6765;&#x5F15;&#x5165;&#xFF0C;params&#x8981;&#x7528;name&#x6765;&#x5F15;&#x5165;&#xFF0C;&#x63A5;&#x6536;&#x53C2;&#x6570;&#x90FD;&#x662F;&#x7C7B;&#x4F3C;&#x7684;&#xFF0C;&#x5206;&#x522B;&#x662F;<span class="hljs-keyword">this</span>.$route.query.name&#x548C;<span class="hljs-keyword">this</span>.$route.params.name&#x3002;

<span class="hljs-comment">// &#x5C55;&#x793A;&#x4E0A;</span>
<span class="hljs-number">2</span>&#xFF1A;query&#x66F4;&#x52A0;&#x7C7B;&#x4F3C;&#x4E8E;&#x6211;&#x4EEC;ajax&#x4E2D;get&#x4F20;&#x53C2;&#xFF0C;params&#x5219;&#x7C7B;&#x4F3C;&#x4E8E;post&#xFF0C;&#x8BF4;&#x7684;&#x518D;&#x7B80;&#x5355;&#x4E00;&#x70B9;&#xFF0C;&#x524D;&#x8005;&#x5728;&#x6D4F;&#x89C8;&#x5668;&#x5730;&#x5740;&#x680F;&#x4E2D;&#x663E;&#x793A;&#x53C2;&#x6570;&#xFF0C;&#x540E;&#x8005;&#x5219;&#x4E0D;&#x663E;&#x793A;

<span class="hljs-number">3</span>&#xFF1A;params&#x662F;&#x8DEF;&#x7531;&#x7684;&#x4E00;&#x90E8;&#x5206;,&#x5FC5;&#x987B;&#x8981;&#x6709;&#x3002;query&#x662F;&#x62FC;&#x63A5;&#x5728;url&#x540E;&#x9762;&#x7684;&#x53C2;&#x6570;&#xFF0C;&#x6CA1;&#x6709;&#x4E5F;&#x6CA1;&#x5173;&#x7CFB;&#x3002;
<span class="hljs-number">4</span>&#xFF1A;params&#x3001;query&#x4E0D;&#x8BBE;&#x7F6E;&#x4E5F;&#x53EF;&#x4EE5;&#x4F20;&#x53C2;&#xFF0C;params&#x4E0D;&#x8BBE;&#x7F6E;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x5237;&#x65B0;&#x9875;&#x9762;&#x6216;&#x8005;&#x8FD4;&#x56DE;&#x53C2;&#x6570;&#x4F1A;&#x4E22;&#x5931;
</code></pre>
<h5 id="23-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;-keep-alive-&#x7684;&#x4F5C;&#x7528;"><a name="23-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;-keep-alive-&#x7684;&#x4F5C;&#x7528;" class="anchor-navigation-ex-anchor" href="#23-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;-keep-alive-&#x7684;&#x4F5C;&#x7528;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="23-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;-keep-alive-&#x7684;&#x4F5C;&#x7528;" class="plugin-anchor" href="#23-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;-keep-alive-&#x7684;&#x4F5C;&#x7528;"><i class="fa fa-link" aria-hidden="true"></i></a>23. &#x2605;&#x2605;&#x2605; Vue&#x4E2D; keep-alive &#x7684;&#x4F5C;&#x7528;</h5>
<pre><code class="lang-JS">keep-alive &#x662F; Vue &#x5185;&#x7F6E;&#x7684;&#x4E00;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF0C;&#x53EF;&#x4EE5;&#x4F7F;&#x88AB;&#x5305;&#x542B;&#x7684;&#x7EC4;&#x4EF6;&#x4FDD;&#x7559;&#x72B6;&#x6001;&#xFF0C;&#x6216;&#x907F;&#x514D;&#x91CD;&#x65B0;&#x6E32;&#x67D3;&#x3002;&#x4E00;&#x65E6;&#x4F7F;&#x7528;keepalive&#x5305;&#x88F9;&#x7EC4;&#x4EF6;&#xFF0C;&#x6B64;&#x65F6;mouted&#xFF0C;created&#x7B49;&#x94A9;&#x5B50;&#x51FD;&#x6570;&#x53EA;&#x4F1A;&#x5728;&#x7B2C;&#x4E00;&#x6B21;&#x8FDB;&#x5165;&#x7EC4;&#x4EF6;&#x65F6;&#x8C03;&#x7528;&#xFF0C;&#x5F53;&#x518D;&#x6B21;&#x5207;&#x6362;&#x56DE;&#x6765;&#x65F6;&#x5C06;&#x4E0D;&#x4F1A;&#x8C03;&#x7528;&#x3002;&#x6B64;&#x65F6;&#x5982;&#x679C;&#x6211;&#x4EEC;&#x8FD8;&#x60F3;&#x5728;&#x6BCF;&#x6B21;&#x5207;&#x6362;&#x65F6;&#x505A;&#x4E00;&#x4E9B;&#x4E8B;&#x60C5;&#xFF0C;&#x5C31;&#x9700;&#x8981;&#x7528;&#x5230;&#x53E6;&#x5916;&#x7684;&#x5468;&#x671F;&#x51FD;&#x6570;&#xFF0C;actived&#x548C;deactived&#xFF0C;&#x8FD9;&#x4E24;&#x4E2A;&#x94A9;&#x5B50;&#x51FD;&#x6570;&#x53EA;&#x6709;&#x88AB;keepalive&#x5305;&#x88F9;&#x540E;&#x624D;&#x4F1A;&#x8C03;&#x7528;&#x3002;
</code></pre>
<h5 id="24-&#x2605;&#x2605;&#x2605;-vue&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x5355;&#x9875;&#x9762;&#x5E94;&#x7528;"><a name="24-&#x2605;&#x2605;&#x2605;-vue&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x5355;&#x9875;&#x9762;&#x5E94;&#x7528;" class="anchor-navigation-ex-anchor" href="#24-&#x2605;&#x2605;&#x2605;-vue&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x5355;&#x9875;&#x9762;&#x5E94;&#x7528;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="24-&#x2605;&#x2605;&#x2605;-vue&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x5355;&#x9875;&#x9762;&#x5E94;&#x7528;" class="plugin-anchor" href="#24-&#x2605;&#x2605;&#x2605;-vue&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x5355;&#x9875;&#x9762;&#x5E94;&#x7528;"><i class="fa fa-link" aria-hidden="true"></i></a>24. &#x2605;&#x2605;&#x2605; Vue&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x5355;&#x9875;&#x9762;&#x5E94;&#x7528;</h5>
<pre><code class="lang-JS">&#x901A;&#x5E38;&#x7684;url &#x5730;&#x5740;&#x7531;&#x4EE5;&#x4E0B;&#x5185;&#x5BB9;&#x6784;&#x6210;&#xFF1A;&#x534F;&#x8BAE;&#x540D; &#x57DF;&#x540D; &#x7AEF;&#x53E3;&#x53F7; &#x8DEF;&#x5F84; &#x53C2;&#x6570; &#x54C8;&#x5E0C;&#x503C;&#xFF0C;&#x5F53;&#x54C8;&#x5E0C;&#x503C;&#x6539;&#x53D8;&#xFF0C;&#x9875;&#x9762;&#x4E0D;&#x4F1A;&#x53D1;&#x751F;&#x8DF3;&#x8F6C;&#xFF0C;&#x5355;&#x9875;&#x9762;&#x5E94;&#x7528;&#x5C31;&#x662F;&#x5229;&#x7528;&#x4E86;&#x8FD9;&#x4E00;&#x70B9;&#xFF0C;&#x7ED9;<span class="hljs-built_in">window</span>&#x6CE8;&#x518C;onhashchange&#x4E8B;&#x4EF6;&#xFF0C;&#x5F53;&#x54C8;&#x5E0C;&#x503C;&#x6539;&#x53D8;&#x65F6;&#x901A;&#x8FC7;location.hash&#x5C31;&#x80FD;&#x83B7;&#x5F97;&#x76F8;&#x5E94;&#x7684;&#x54C8;&#x5E0C;&#x503C;&#xFF0C;&#x7136;&#x540E;&#x5C31;&#x80FD;&#x8DF3;&#x5230;&#x76F8;&#x5E94;&#x7684;&#x9875;&#x9762;&#x3002;
</code></pre>
<h5 id="25-&#x2605;&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x660E;&#x4E00;&#x4E0B;&#x5C01;&#x88C5;vue&#x7EC4;&#x4EF6;&#x7684;&#x539F;&#x5219;&#x548C;&#x65B9;&#x6CD5;"><a name="25-&#x2605;&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x660E;&#x4E00;&#x4E0B;&#x5C01;&#x88C5;vue&#x7EC4;&#x4EF6;&#x7684;&#x539F;&#x5219;&#x548C;&#x65B9;&#x6CD5;" class="anchor-navigation-ex-anchor" href="#25-&#x2605;&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x660E;&#x4E00;&#x4E0B;&#x5C01;&#x88C5;vue&#x7EC4;&#x4EF6;&#x7684;&#x539F;&#x5219;&#x548C;&#x65B9;&#x6CD5;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="25-&#x2605;&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x660E;&#x4E00;&#x4E0B;&#x5C01;&#x88C5;vue&#x7EC4;&#x4EF6;&#x7684;&#x539F;&#x5219;&#x548C;&#x65B9;&#x6CD5;" class="plugin-anchor" href="#25-&#x2605;&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x660E;&#x4E00;&#x4E0B;&#x5C01;&#x88C5;vue&#x7EC4;&#x4EF6;&#x7684;&#x539F;&#x5219;&#x548C;&#x65B9;&#x6CD5;"><i class="fa fa-link" aria-hidden="true"></i></a>25. &#x2605;&#x2605;&#x2605;&#x2605; &#x8BF4;&#x660E;&#x4E00;&#x4E0B;&#x5C01;&#x88C5;vue&#x7EC4;&#x4EF6;&#x7684;&#x539F;&#x5219;&#x548C;&#x65B9;&#x6CD5;</h5>
<pre><code class="lang-JS"><span class="hljs-comment">// &#x7B54;&#x6848;&#xFF1A;</span>
</code></pre>
<h5 id="26-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x51FA;&#x81F3;&#x5C11;4&#x79CD;vue&#x5F53;&#x4E2D;&#x7684;&#x6307;&#x4EE4;&#x548C;&#x5B83;&#x7684;&#x7528;&#x6CD5;&#xFF1F;"><a name="26-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x51FA;&#x81F3;&#x5C11;4&#x79CD;vue&#x5F53;&#x4E2D;&#x7684;&#x6307;&#x4EE4;&#x548C;&#x5B83;&#x7684;&#x7528;&#x6CD5;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#26-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x51FA;&#x81F3;&#x5C11;4&#x79CD;vue&#x5F53;&#x4E2D;&#x7684;&#x6307;&#x4EE4;&#x548C;&#x5B83;&#x7684;&#x7528;&#x6CD5;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="26-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x51FA;&#x81F3;&#x5C11;4&#x79CD;vue&#x5F53;&#x4E2D;&#x7684;&#x6307;&#x4EE4;&#x548C;&#x5B83;&#x7684;&#x7528;&#x6CD5;&#xFF1F;" class="plugin-anchor" href="#26-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x51FA;&#x81F3;&#x5C11;4&#x79CD;vue&#x5F53;&#x4E2D;&#x7684;&#x6307;&#x4EE4;&#x548C;&#x5B83;&#x7684;&#x7528;&#x6CD5;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>26. &#x2605;&#x2605;&#x2605; &#x8BF4;&#x51FA;&#x81F3;&#x5C11;4&#x79CD;Vue&#x5F53;&#x4E2D;&#x7684;&#x6307;&#x4EE4;&#x548C;&#x5B83;&#x7684;&#x7528;&#x6CD5;&#xFF1F;</h5>
<pre><code class="lang-JS">v-<span class="hljs-keyword">if</span>(&#x5224;&#x65AD;&#x662F;&#x5426;&#x9690;&#x85CF;&#xFF0C;&#x7528;&#x6765;&#x5224;&#x65AD;&#x5143;&#x7D20;&#x662F;&#x5426;&#x521B;&#x5EFA;)
v-show(&#x5143;&#x7D20;&#x7684;&#x663E;&#x793A;&#x9690;&#x85CF;&#xFF0C;&#x7C7B;&#x4F3C;css&#x4E2D;&#x7684;display&#x7684;block&#x548C;hidden)
v-<span class="hljs-keyword">for</span>(&#x628A;&#x6570;&#x636E;&#x904D;&#x5386;&#x51FA;&#x6765;)
v-bind(&#x7ED1;&#x5B9A;&#x5C5E;&#x6027;)
v-model(&#x5B9E;&#x73B0;&#x53CC;&#x5411;&#x7ED1;&#x5B9A;)
</code></pre>
<h5 id="27-&#x2605;&#x2605;&#x2605;-vuex&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;&#x63CF;&#x8FF0;&#x4F7F;&#x7528;&#x5B83;&#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD;&#x7684;&#x6D41;&#x7A0B;&#xFF1F;"><a name="27-&#x2605;&#x2605;&#x2605;-vuex&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;&#x63CF;&#x8FF0;&#x4F7F;&#x7528;&#x5B83;&#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD;&#x7684;&#x6D41;&#x7A0B;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#27-&#x2605;&#x2605;&#x2605;-vuex&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;&#x63CF;&#x8FF0;&#x4F7F;&#x7528;&#x5B83;&#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD;&#x7684;&#x6D41;&#x7A0B;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="27-&#x2605;&#x2605;&#x2605;-vuex&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;&#x63CF;&#x8FF0;&#x4F7F;&#x7528;&#x5B83;&#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD;&#x7684;&#x6D41;&#x7A0B;&#xFF1F;" class="plugin-anchor" href="#27-&#x2605;&#x2605;&#x2605;-vuex&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;&#x63CF;&#x8FF0;&#x4F7F;&#x7528;&#x5B83;&#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD;&#x7684;&#x6D41;&#x7A0B;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>27. &#x2605;&#x2605;&#x2605; Vuex&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;&#x63CF;&#x8FF0;&#x4F7F;&#x7528;&#x5B83;&#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD;&#x7684;&#x6D41;&#x7A0B;&#xFF1F;</h5>
<pre><code class="lang-JS">

</code></pre>
<h5 id="28-&#x2605;&#x2605;&#x2605;-&#x8C08;&#x8C08;vue&#x751F;&#x547D;&#x5468;&#x671F;&#x51FD;&#x6570;&#xFF1F;vue&#x7684;&#x5B9E;&#x4F8B;&#x9009;&#x9879;&#x5BF9;&#x8C61;&#xFF1F;&#x8C08;&#x8C08;&#x52A8;&#x6001;&#x6570;&#x636E;&#x7ED1;&#x5B9A;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x5982;&#x4F55;&#x5207;&#x6362;&#x8DEF;&#x7531;&#x3002;&#x6709;&#x54EA;&#x4E9B;&#x65B9;&#x6CD5;&#x4F20;&#x503C;&#x5230;&#x4E0B;&#x4E00;&#x4E2A;&#x9875;&#x9762;&#xFF0C;&#x533A;&#x522B;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;"><a name="28-&#x2605;&#x2605;&#x2605;-&#x8C08;&#x8C08;vue&#x751F;&#x547D;&#x5468;&#x671F;&#x51FD;&#x6570;&#xFF1F;vue&#x7684;&#x5B9E;&#x4F8B;&#x9009;&#x9879;&#x5BF9;&#x8C61;&#xFF1F;&#x8C08;&#x8C08;&#x52A8;&#x6001;&#x6570;&#x636E;&#x7ED1;&#x5B9A;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x5982;&#x4F55;&#x5207;&#x6362;&#x8DEF;&#x7531;&#x3002;&#x6709;&#x54EA;&#x4E9B;&#x65B9;&#x6CD5;&#x4F20;&#x503C;&#x5230;&#x4E0B;&#x4E00;&#x4E2A;&#x9875;&#x9762;&#xFF0C;&#x533A;&#x522B;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#28-&#x2605;&#x2605;&#x2605;-&#x8C08;&#x8C08;vue&#x751F;&#x547D;&#x5468;&#x671F;&#x51FD;&#x6570;&#xFF1F;vue&#x7684;&#x5B9E;&#x4F8B;&#x9009;&#x9879;&#x5BF9;&#x8C61;&#xFF1F;&#x8C08;&#x8C08;&#x52A8;&#x6001;&#x6570;&#x636E;&#x7ED1;&#x5B9A;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x5982;&#x4F55;&#x5207;&#x6362;&#x8DEF;&#x7531;&#x3002;&#x6709;&#x54EA;&#x4E9B;&#x65B9;&#x6CD5;&#x4F20;&#x503C;&#x5230;&#x4E0B;&#x4E00;&#x4E2A;&#x9875;&#x9762;&#xFF0C;&#x533A;&#x522B;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="28-&#x2605;&#x2605;&#x2605;-&#x8C08;&#x8C08;vue&#x751F;&#x547D;&#x5468;&#x671F;&#x51FD;&#x6570;&#xFF1F;vue&#x7684;&#x5B9E;&#x4F8B;&#x9009;&#x9879;&#x5BF9;&#x8C61;&#xFF1F;&#x8C08;&#x8C08;&#x52A8;&#x6001;&#x6570;&#x636E;&#x7ED1;&#x5B9A;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x5982;&#x4F55;&#x5207;&#x6362;&#x8DEF;&#x7531;&#x3002;&#x6709;&#x54EA;&#x4E9B;&#x65B9;&#x6CD5;&#x4F20;&#x503C;&#x5230;&#x4E0B;&#x4E00;&#x4E2A;&#x9875;&#x9762;&#xFF0C;&#x533A;&#x522B;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;" class="plugin-anchor" href="#28-&#x2605;&#x2605;&#x2605;-&#x8C08;&#x8C08;vue&#x751F;&#x547D;&#x5468;&#x671F;&#x51FD;&#x6570;&#xFF1F;vue&#x7684;&#x5B9E;&#x4F8B;&#x9009;&#x9879;&#x5BF9;&#x8C61;&#xFF1F;&#x8C08;&#x8C08;&#x52A8;&#x6001;&#x6570;&#x636E;&#x7ED1;&#x5B9A;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x5982;&#x4F55;&#x5207;&#x6362;&#x8DEF;&#x7531;&#x3002;&#x6709;&#x54EA;&#x4E9B;&#x65B9;&#x6CD5;&#x4F20;&#x503C;&#x5230;&#x4E0B;&#x4E00;&#x4E2A;&#x9875;&#x9762;&#xFF0C;&#x533A;&#x522B;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>28. &#x2605;&#x2605;&#x2605; &#x8C08;&#x8C08;vue&#x751F;&#x547D;&#x5468;&#x671F;&#x51FD;&#x6570;&#xFF1F;vue&#x7684;&#x5B9E;&#x4F8B;&#x9009;&#x9879;&#x5BF9;&#x8C61;&#xFF1F;&#x8C08;&#x8C08;&#x52A8;&#x6001;&#x6570;&#x636E;&#x7ED1;&#x5B9A;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x5982;&#x4F55;&#x5207;&#x6362;&#x8DEF;&#x7531;&#x3002;&#x6709;&#x54EA;&#x4E9B;&#x65B9;&#x6CD5;&#x4F20;&#x503C;&#x5230;&#x4E0B;&#x4E00;&#x4E2A;&#x9875;&#x9762;&#xFF0C;&#x533A;&#x522B;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;</h5>
<pre><code class="lang-JS">

</code></pre>
<h5 id="29-&#x2605;&#x2605;&#x2605;-vue-loader&#x89E3;&#x91CA;&#x4E00;&#x4E0B;"><a name="29-&#x2605;&#x2605;&#x2605;-vue-loader&#x89E3;&#x91CA;&#x4E00;&#x4E0B;" class="anchor-navigation-ex-anchor" href="#29-&#x2605;&#x2605;&#x2605;-vue-loader&#x89E3;&#x91CA;&#x4E00;&#x4E0B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="29-&#x2605;&#x2605;&#x2605;-vue-loader&#x89E3;&#x91CA;&#x4E00;&#x4E0B;" class="plugin-anchor" href="#29-&#x2605;&#x2605;&#x2605;-vue-loader&#x89E3;&#x91CA;&#x4E00;&#x4E0B;"><i class="fa fa-link" aria-hidden="true"></i></a>29. &#x2605;&#x2605;&#x2605; Vue-loader&#x89E3;&#x91CA;&#x4E00;&#x4E0B;</h5>
<pre><code class="lang-JS">&#x89E3;&#x6790;&#x548C;&#x8F6C;&#x6362; .vue &#x6587;&#x4EF6;&#xFF0C;&#x63D0;&#x53D6;&#x51FA;&#x5176;&#x4E2D;&#x7684;&#x903B;&#x8F91;&#x4EE3;&#x7801; script&#x3001;&#x6837;&#x5F0F;&#x4EE3;&#x7801; style&#x3001;&#x4EE5;&#x53CA; HTML &#x6A21;&#x7248; template&#xFF0C;&#x518D;&#x5206;&#x522B;&#x628A;&#x5B83;&#x4EEC;&#x4EA4;&#x7ED9;&#x5BF9;&#x5E94;&#x7684; Loader &#x53BB;&#x5904;&#x7406;&#x3002;
</code></pre>
<h5 id="30-&#x2605;&#x2605;-&#x7528;-vue-&#x5C01;&#x88C5;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF0C;&#x53EF;&#x4EE5;&#x81EA;&#x5B9A;&#x4E49;&#x91CC;&#x9762;&#x6709;&#x591A;&#x5C11;&#x4E2A;input"><a name="30-&#x2605;&#x2605;-&#x7528;-vue-&#x5C01;&#x88C5;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF0C;&#x53EF;&#x4EE5;&#x81EA;&#x5B9A;&#x4E49;&#x91CC;&#x9762;&#x6709;&#x591A;&#x5C11;&#x4E2A;input" class="anchor-navigation-ex-anchor" href="#30-&#x2605;&#x2605;-&#x7528;-vue-&#x5C01;&#x88C5;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF0C;&#x53EF;&#x4EE5;&#x81EA;&#x5B9A;&#x4E49;&#x91CC;&#x9762;&#x6709;&#x591A;&#x5C11;&#x4E2A;input"><i class="fa fa-link" aria-hidden="true"></i></a><a name="30-&#x2605;&#x2605;-&#x7528;-vue-&#x5C01;&#x88C5;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF0C;&#x53EF;&#x4EE5;&#x81EA;&#x5B9A;&#x4E49;&#x91CC;&#x9762;&#x6709;&#x591A;&#x5C11;&#x4E2A;input" class="plugin-anchor" href="#30-&#x2605;&#x2605;-&#x7528;-vue-&#x5C01;&#x88C5;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF0C;&#x53EF;&#x4EE5;&#x81EA;&#x5B9A;&#x4E49;&#x91CC;&#x9762;&#x6709;&#x591A;&#x5C11;&#x4E2A;input"><i class="fa fa-link" aria-hidden="true"></i></a>30. &#x2605;&#x2605; &#x7528; Vue &#x5C01;&#x88C5;&#x4E2A;&#x7EC4;&#x4EF6;&#xFF0C;&#x53EF;&#x4EE5;&#x81EA;&#x5B9A;&#x4E49;&#x91CC;&#x9762;&#x6709;&#x591A;&#x5C11;&#x4E2A;input</h5>
<pre><code class="lang-JS"><span class="hljs-comment">// &#x7B54;&#x6848;&#xFF1A;</span>
</code></pre>
<h5 id="31-&#x2605;&#x2605;&#x2605;-&#x7528;&#x8FC7;&#x63D2;&#x69FD;&#x5417;&#xFF1F;&#x7528;&#x7684;&#x662F;&#x5177;&#x540D;&#x63D2;&#x69FD;&#x8FD8;&#x662F;&#x533F;&#x540D;&#x63D2;&#x69FD;"><a name="31-&#x2605;&#x2605;&#x2605;-&#x7528;&#x8FC7;&#x63D2;&#x69FD;&#x5417;&#xFF1F;&#x7528;&#x7684;&#x662F;&#x5177;&#x540D;&#x63D2;&#x69FD;&#x8FD8;&#x662F;&#x533F;&#x540D;&#x63D2;&#x69FD;" class="anchor-navigation-ex-anchor" href="#31-&#x2605;&#x2605;&#x2605;-&#x7528;&#x8FC7;&#x63D2;&#x69FD;&#x5417;&#xFF1F;&#x7528;&#x7684;&#x662F;&#x5177;&#x540D;&#x63D2;&#x69FD;&#x8FD8;&#x662F;&#x533F;&#x540D;&#x63D2;&#x69FD;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="31-&#x2605;&#x2605;&#x2605;-&#x7528;&#x8FC7;&#x63D2;&#x69FD;&#x5417;&#xFF1F;&#x7528;&#x7684;&#x662F;&#x5177;&#x540D;&#x63D2;&#x69FD;&#x8FD8;&#x662F;&#x533F;&#x540D;&#x63D2;&#x69FD;" class="plugin-anchor" href="#31-&#x2605;&#x2605;&#x2605;-&#x7528;&#x8FC7;&#x63D2;&#x69FD;&#x5417;&#xFF1F;&#x7528;&#x7684;&#x662F;&#x5177;&#x540D;&#x63D2;&#x69FD;&#x8FD8;&#x662F;&#x533F;&#x540D;&#x63D2;&#x69FD;"><i class="fa fa-link" aria-hidden="true"></i></a>31. &#x2605;&#x2605;&#x2605; &#x7528;&#x8FC7;&#x63D2;&#x69FD;&#x5417;&#xFF1F;&#x7528;&#x7684;&#x662F;&#x5177;&#x540D;&#x63D2;&#x69FD;&#x8FD8;&#x662F;&#x533F;&#x540D;&#x63D2;&#x69FD;</h5>
<pre><code class="lang-JS">&#x7528;&#x8FC7;&#xFF0C;&#x90FD;&#x4F7F;&#x7528;&#x8FC7;&#x3002;&#x63D2;&#x69FD;&#x76F8;&#x5F53;&#x4E8E;&#x9884;&#x7559;&#x4E86;&#x4E00;&#x4E2A;&#x4F4D;&#x7F6E;&#xFF0C;&#x53EF;&#x4EE5;&#x5C06;&#x6211;&#x4EEC;&#x4E66;&#x5199;&#x5728;&#x7EC4;&#x4EF6;&#x5185;&#x7684;&#x5185;&#x5BB9;&#x653E;&#x5165;&#xFF0C;&#x5199;&#x4E00;&#x4E2A;&#x63D2;&#x69FD;&#x5C31;&#x4F1A;&#x5C06;&#x7EC4;&#x4EF6;&#x5185;&#x7684;&#x5185;&#x5BB9;&#x66FF;&#x6362;&#x4E00;&#x6B21;&#xFF0C;&#x4E24;&#x6B21;&#x5219;&#x66FF;&#x6362;&#x4E24;&#x6B21;&#x3002;&#x4E3A;&#x4E86;&#x81EA;&#x5B9A;&#x4E49;&#x63D2;&#x69FD;&#x7684;&#x4F4D;&#x7F6E;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x7ED9;&#x63D2;&#x69FD;&#x53D6;&#x540D;&#xFF0C;&#x5B83;&#x4F1A;&#x6839;&#x636E;&#x63D2;&#x69FD;&#x540D;&#x6765;&#x63D2;&#x5165;&#x5185;&#x5BB9;&#xFF0C;&#x4E00;&#x4E00;&#x5BF9;&#x5E94;&#x3002;
</code></pre>
<h5 id="32-&#x2605;&#x2605;&#x2605;-vue-cli&#x8FD0;&#x884C;&#x7684;&#x547D;&#x4EE4;&#x884C;"><a name="32-&#x2605;&#x2605;&#x2605;-vue-cli&#x8FD0;&#x884C;&#x7684;&#x547D;&#x4EE4;&#x884C;" class="anchor-navigation-ex-anchor" href="#32-&#x2605;&#x2605;&#x2605;-vue-cli&#x8FD0;&#x884C;&#x7684;&#x547D;&#x4EE4;&#x884C;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="32-&#x2605;&#x2605;&#x2605;-vue-cli&#x8FD0;&#x884C;&#x7684;&#x547D;&#x4EE4;&#x884C;" class="plugin-anchor" href="#32-&#x2605;&#x2605;&#x2605;-vue-cli&#x8FD0;&#x884C;&#x7684;&#x547D;&#x4EE4;&#x884C;"><i class="fa fa-link" aria-hidden="true"></i></a>32. &#x2605;&#x2605;&#x2605; Vue-cli&#x8FD0;&#x884C;&#x7684;&#x547D;&#x4EE4;&#x884C;</h5>
<pre><code class="lang-JS"><span class="hljs-comment">// &#x7B54;&#x6848;&#xFF1A;</span>
</code></pre>
<h5 id="33-&#x2605;&#x2605;&#x2605;-vue-&#x8DEF;&#x7531;&#x5B88;&#x536B;"><a name="33-&#x2605;&#x2605;&#x2605;-vue-&#x8DEF;&#x7531;&#x5B88;&#x536B;" class="anchor-navigation-ex-anchor" href="#33-&#x2605;&#x2605;&#x2605;-vue-&#x8DEF;&#x7531;&#x5B88;&#x536B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="33-&#x2605;&#x2605;&#x2605;-vue-&#x8DEF;&#x7531;&#x5B88;&#x536B;" class="plugin-anchor" href="#33-&#x2605;&#x2605;&#x2605;-vue-&#x8DEF;&#x7531;&#x5B88;&#x536B;"><i class="fa fa-link" aria-hidden="true"></i></a>33. &#x2605;&#x2605;&#x2605; Vue &#x8DEF;&#x7531;&#x5B88;&#x536B;</h5>
<pre><code class="lang-JS">vue-router &#x63D0;&#x4F9B;&#x7684;&#x5BFC;&#x822A;&#x5B88;&#x536B;&#x4E3B;&#x8981;&#x7528;&#x6765;&#x5BF9;&#x8DEF;&#x7531;&#x7684;&#x8DF3;&#x8F6C;&#x8FDB;&#x884C;&#x76D1;&#x63A7;&#xFF0C;&#x63A7;&#x5236;&#x5B83;&#x7684;&#x8DF3;&#x8F6C;&#x6216;&#x53D6;&#x6D88;&#xFF0C;&#x8DEF;&#x7531;&#x5B88;&#x536B;&#x6709;&#x5168;&#x5C40;&#x7684;, &#x5355;&#x4E2A;&#x8DEF;&#x7531;&#x72EC;&#x4EAB;&#x7684;, &#x6216;&#x8005;&#x7EC4;&#x4EF6;&#x7EA7;&#x7684;&#x3002;&#x5BFC;&#x822A;&#x94A9;&#x5B50;&#x6709;<span class="hljs-number">3</span>&#x4E2A;&#x53C2;&#x6570;&#xFF1A;

<span class="hljs-number">1</span>&#x3001;to:&#x5373;&#x5C06;&#x8981;&#x8FDB;&#x5165;&#x7684;&#x76EE;&#x6807;&#x8DEF;&#x7531;&#x5BF9;&#x8C61;&#xFF1B;
<span class="hljs-number">2</span>&#x3001;<span class="hljs-keyword">from</span>:&#x5F53;&#x524D;&#x5BFC;&#x822A;&#x5373;&#x5C06;&#x8981;&#x79BB;&#x5F00;&#x7684;&#x8DEF;&#x7531;&#x5BF9;&#x8C61;&#xFF1B;
<span class="hljs-number">3</span>&#x3001;next &#xFF1A;&#x8C03;&#x7528;&#x8BE5;&#x65B9;&#x6CD5;&#x540E;&#xFF0C;&#x624D;&#x80FD;&#x8FDB;&#x5165;&#x4E0B;&#x4E00;&#x4E2A;&#x94A9;&#x5B50;&#x51FD;&#x6570;&#xFF08;afterEach&#xFF09;&#x3002;
</code></pre>
<h5 id="34-&#x2605;&#x2605;-vue&#x4E2D;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x5B50;&#x7EC4;&#x4EF6;&#x5185;&#x7684;css&#x6837;&#x5F0F;&#x540D;&#x5728;&#x9879;&#x76EE;&#x4E2D;&#x7EDD;&#x5BF9;&#x552F;&#x4E00;&#x6027;"><a name="34-&#x2605;&#x2605;-vue&#x4E2D;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x5B50;&#x7EC4;&#x4EF6;&#x5185;&#x7684;css&#x6837;&#x5F0F;&#x540D;&#x5728;&#x9879;&#x76EE;&#x4E2D;&#x7EDD;&#x5BF9;&#x552F;&#x4E00;&#x6027;" class="anchor-navigation-ex-anchor" href="#34-&#x2605;&#x2605;-vue&#x4E2D;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x5B50;&#x7EC4;&#x4EF6;&#x5185;&#x7684;css&#x6837;&#x5F0F;&#x540D;&#x5728;&#x9879;&#x76EE;&#x4E2D;&#x7EDD;&#x5BF9;&#x552F;&#x4E00;&#x6027;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="34-&#x2605;&#x2605;-vue&#x4E2D;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x5B50;&#x7EC4;&#x4EF6;&#x5185;&#x7684;css&#x6837;&#x5F0F;&#x540D;&#x5728;&#x9879;&#x76EE;&#x4E2D;&#x7EDD;&#x5BF9;&#x552F;&#x4E00;&#x6027;" class="plugin-anchor" href="#34-&#x2605;&#x2605;-vue&#x4E2D;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x5B50;&#x7EC4;&#x4EF6;&#x5185;&#x7684;css&#x6837;&#x5F0F;&#x540D;&#x5728;&#x9879;&#x76EE;&#x4E2D;&#x7EDD;&#x5BF9;&#x552F;&#x4E00;&#x6027;"><i class="fa fa-link" aria-hidden="true"></i></a>34. &#x2605;&#x2605; Vue&#x4E2D;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x5B50;&#x7EC4;&#x4EF6;&#x5185;&#x7684;css&#x6837;&#x5F0F;&#x540D;&#x5728;&#x9879;&#x76EE;&#x4E2D;&#x7EDD;&#x5BF9;&#x552F;&#x4E00;&#x6027;</h5>
<pre><code class="lang-JS">&#x5728;style&#x6807;&#x7B7E;&#x4E0A;&#x52A0;&#x4E0A;scoped&#x5C5E;&#x6027;
</code></pre>
<h5 id="35-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue3&#x4E2D;&#x7684;&#x53CC;&#x5411;&#x6570;&#x636E;&#x7ED1;&#x5B9A;proxy"><a name="35-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue3&#x4E2D;&#x7684;&#x53CC;&#x5411;&#x6570;&#x636E;&#x7ED1;&#x5B9A;proxy" class="anchor-navigation-ex-anchor" href="#35-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue3&#x4E2D;&#x7684;&#x53CC;&#x5411;&#x6570;&#x636E;&#x7ED1;&#x5B9A;proxy"><i class="fa fa-link" aria-hidden="true"></i></a><a name="35-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue3&#x4E2D;&#x7684;&#x53CC;&#x5411;&#x6570;&#x636E;&#x7ED1;&#x5B9A;proxy" class="plugin-anchor" href="#35-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue3&#x4E2D;&#x7684;&#x53CC;&#x5411;&#x6570;&#x636E;&#x7ED1;&#x5B9A;proxy"><i class="fa fa-link" aria-hidden="true"></i></a>35. &#x2605;&#x2605;&#x2605;&#x2605;&#x2605; Vue3&#x4E2D;&#x7684;&#x53CC;&#x5411;&#x6570;&#x636E;&#x7ED1;&#x5B9A;proxy</h5>
<pre><code class="lang-JS"><span class="hljs-built_in">Proxy</span>&#x76F8;&#x5F53;&#x4E8E;&#x5728;&#x76EE;&#x6807;&#x5BF9;&#x8C61;&#x4E4B;&#x524D;&#x67B6;&#x8BBE;&#x4E00;&#x5C42;&#x201C;&#x62E6;&#x622A;&#x201D;&#xFF0C;&#x5916;&#x754C;&#x5BF9;&#x8BE5;&#x5BF9;&#x8C61;&#x7684;&#x8BBF;&#x95EE;&#xFF0C;&#x90FD;&#x5FC5;&#x987B;&#x5148;&#x901A;&#x8FC7;&#x8FD9;&#x5C42;&#x62E6;&#x622A;&#xFF0C;&#x56E0;&#x6B64;&#x63D0;&#x4F9B;&#x4E86;&#x4E00;&#x79CD;&#x673A;&#x5236;&#xFF0C;&#x53EF;&#x4EE5;&#x5BF9;&#x5916;&#x754C;&#x7684;&#x8BBF;&#x95EE;&#x8FDB;&#x884C;&#x8FC7;&#x6EE4;&#x548C;&#x6539;&#x5199;,&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x8FD9;&#x6837;&#x8BA4;&#x4E3A;,<span class="hljs-built_in">Proxy</span>&#x662F;<span class="hljs-built_in">Object</span>.defineProperty&#x7684;&#x5168;&#x65B9;&#x4F4D;&#x52A0;&#x5F3A;&#x7248;&#xFF0C;&#x5B83;&#x89E3;&#x51B3;&#x4E86;&#x4E4B;&#x524D;defineProperty&#x65E0;&#x6CD5;&#x76D1;&#x542C;&#x5230;&#x6570;&#x7EC4;&#x53D8;&#x5316;&#x7B49;&#x7F3A;&#x70B9;&#x3002;
</code></pre>
<h5 id="36-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-55&#x3001;vue&#x548C;react&#x4E2D;diff&#x7B97;&#x6CD5;&#x533A;&#x522B;"><a name="36-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-55&#x3001;vue&#x548C;react&#x4E2D;diff&#x7B97;&#x6CD5;&#x533A;&#x522B;" class="anchor-navigation-ex-anchor" href="#36-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-55&#x3001;vue&#x548C;react&#x4E2D;diff&#x7B97;&#x6CD5;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="36-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-55&#x3001;vue&#x548C;react&#x4E2D;diff&#x7B97;&#x6CD5;&#x533A;&#x522B;" class="plugin-anchor" href="#36-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-55&#x3001;vue&#x548C;react&#x4E2D;diff&#x7B97;&#x6CD5;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a>36. &#x2605;&#x2605;&#x2605;&#x2605;&#x2605; 55&#x3001;Vue&#x548C;React&#x4E2D;diff&#x7B97;&#x6CD5;&#x533A;&#x522B;</h5>
<pre><code class="lang-JS">vue&#x548C;react&#x7684;diff&#x7B97;&#x6CD5;&#xFF0C;&#x90FD;&#x662F;&#x5FFD;&#x7565;&#x8DE8;&#x7EA7;&#x6BD4;&#x8F83;&#xFF0C;&#x53EA;&#x505A;&#x540C;&#x7EA7;&#x6BD4;&#x8F83;&#x3002;vue diff&#x65F6;&#x8C03;&#x52A8;patch&#x51FD;&#x6570;&#xFF0C;&#x53C2;&#x6570;&#x662F;vnode&#x548C;oldVnode&#xFF0C;&#x5206;&#x522B;&#x4EE3;&#x8868;&#x65B0;&#x65E7;&#x8282;&#x70B9;&#x3002;

<span class="hljs-number">1.</span>vue&#x5BF9;&#x6BD4;&#x8282;&#x70B9;&#x3002;&#x5F53;&#x8282;&#x70B9;&#x5143;&#x7D20;&#x76F8;&#x540C;&#xFF0C;&#x4F46;&#x662F;classname&#x4E0D;&#x540C;&#xFF0C;&#x8BA4;&#x4E3A;&#x662F;&#x4E0D;&#x540C;&#x7C7B;&#x578B;&#x7684;&#x5143;&#x7D20;&#xFF0C;&#x5220;&#x9664;&#x91CD;&#x5EFA;&#xFF0C;&#x800C;react&#x8BA4;&#x4E3A;&#x662F;&#x540C;&#x7C7B;&#x578B;&#x8282;&#x70B9;&#xFF0C;&#x53EA;&#x662F;&#x4FEE;&#x6539;&#x8282;&#x70B9;&#x5C5E;&#x6027;&#x3002;

<span class="hljs-number">2.</span>vue&#x7684;&#x5217;&#x8868;&#x5BF9;&#x6BD4;&#xFF0C;&#x91C7;&#x7528;&#x7684;&#x662F;&#x4E24;&#x7AEF;&#x5230;&#x4E2D;&#x95F4;&#x6BD4;&#x5BF9;&#x7684;&#x65B9;&#x5F0F;&#xFF0C;&#x800C;react&#x91C7;&#x7528;&#x7684;&#x662F;&#x4ECE;&#x5DE6;&#x5230;&#x53F3;&#x4F9D;&#x6B21;&#x5BF9;&#x6BD4;&#x7684;&#x65B9;&#x5F0F;&#x3002;&#x5F53;&#x4E00;&#x4E2A;&#x96C6;&#x5408;&#x53EA;&#x662F;&#x628A;&#x6700;&#x540E;&#x4E00;&#x4E2A;&#x8282;&#x70B9;&#x79FB;&#x5230;&#x4E86;&#x7B2C;&#x4E00;&#x4E2A;&#xFF0C;react&#x4F1A;&#x628A;&#x524D;&#x9762;&#x7684;&#x8282;&#x70B9;&#x4F9D;&#x6B21;&#x79FB;&#x52A8;&#xFF0C;&#x800C;vue&#x53EA;&#x4F1A;&#x628A;&#x6700;&#x540E;&#x4E00;&#x4E2A;&#x8282;&#x70B9;&#x79FB;&#x5230;&#x7B2C;&#x4E00;&#x4E2A;&#x3002;&#x603B;&#x4F53;&#x4E0A;&#xFF0C;vue&#x7684;&#x65B9;&#x5F0F;&#x6BD4;&#x8F83;&#x9AD8;&#x6548;&#x3002;
</code></pre>
<h5 id="37-&#x2605;&#x2605;&#x2605;-&#x8BF7;&#x4F60;&#x8BF4;&#x4E00;&#x4E0B;-vue-&#x4E2D;-create-&#x548C;-mount-&#x7684;&#x533A;&#x522B;"><a name="37-&#x2605;&#x2605;&#x2605;-&#x8BF7;&#x4F60;&#x8BF4;&#x4E00;&#x4E0B;-vue-&#x4E2D;-create-&#x548C;-mount-&#x7684;&#x533A;&#x522B;" class="anchor-navigation-ex-anchor" href="#37-&#x2605;&#x2605;&#x2605;-&#x8BF7;&#x4F60;&#x8BF4;&#x4E00;&#x4E0B;-vue-&#x4E2D;-create-&#x548C;-mount-&#x7684;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="37-&#x2605;&#x2605;&#x2605;-&#x8BF7;&#x4F60;&#x8BF4;&#x4E00;&#x4E0B;-vue-&#x4E2D;-create-&#x548C;-mount-&#x7684;&#x533A;&#x522B;" class="plugin-anchor" href="#37-&#x2605;&#x2605;&#x2605;-&#x8BF7;&#x4F60;&#x8BF4;&#x4E00;&#x4E0B;-vue-&#x4E2D;-create-&#x548C;-mount-&#x7684;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a>37. &#x2605;&#x2605;&#x2605; &#x8BF7;&#x4F60;&#x8BF4;&#x4E00;&#x4E0B; Vue &#x4E2D; create &#x548C; mount &#x7684;&#x533A;&#x522B;</h5>
<pre><code class="lang-JS">create&#x4E3A;&#x7EC4;&#x4EF6;&#x521D;&#x59CB;&#x5316;&#x9636;&#x6BB5;&#xFF0C;&#x5728;&#x6B64;&#x9636;&#x6BB5;&#x4E3B;&#x8981;&#x5B8C;&#x6210;&#x6570;&#x636E;&#x89C2;&#x6D4B;(data observer)&#xFF0C;&#x5C5E;&#x6027;&#x548C;&#x65B9;&#x6CD5;&#x7684;&#x8FD0;&#x7B97;&#xFF0C; watch/event &#x4E8B;&#x4EF6;&#x56DE;&#x8C03;&#x3002;&#x7136;&#x800C;&#xFF0C;&#x6302;&#x8F7D;&#x9636;&#x6BB5;&#x8FD8;&#x6CA1;&#x5F00;&#x59CB;&#xFF0C;&#x6B64;&#x65F6;&#x8FD8;&#x672A;&#x751F;&#x6210;&#x771F;&#x5B9E;&#x7684;DOM&#xFF0C;&#x4E5F;&#x5C31;&#x65E0;&#x6CD5;&#x83B7;&#x53D6;&#x548C;&#x64CD;&#x4F5C;DOM&#x5143;&#x7D20;&#x3002;&#x800C;mount&#x4E3B;&#x8981;&#x5B8C;&#x6210;&#x4ECE;&#x865A;&#x62DF;DOM&#x5230;&#x771F;&#x5B9E;DOM&#x7684;&#x8F6C;&#x6362;&#x6302;&#x8F7D;&#xFF0C;&#x6B64;&#x65F6;html&#x5DF2;&#x7ECF;&#x6E32;&#x67D3;&#x51FA;&#x6765;&#x4E86;&#xFF0C;&#x6240;&#x4EE5;&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x64CD;&#x4F5C;dom&#x8282;&#x70B9;&#x3002;
</code></pre>
<h5 id="38-&#x2605;&#x2605;&#x2605;&#x2605;-objectdefineproperty&#x6709;&#x4EC0;&#x4E48;&#x7F3A;&#x70B9;"><a name="38-&#x2605;&#x2605;&#x2605;&#x2605;-objectdefineproperty&#x6709;&#x4EC0;&#x4E48;&#x7F3A;&#x70B9;" class="anchor-navigation-ex-anchor" href="#38-&#x2605;&#x2605;&#x2605;&#x2605;-objectdefineproperty&#x6709;&#x4EC0;&#x4E48;&#x7F3A;&#x70B9;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="38-&#x2605;&#x2605;&#x2605;&#x2605;-objectdefineproperty&#x6709;&#x4EC0;&#x4E48;&#x7F3A;&#x70B9;" class="plugin-anchor" href="#38-&#x2605;&#x2605;&#x2605;&#x2605;-objectdefineproperty&#x6709;&#x4EC0;&#x4E48;&#x7F3A;&#x70B9;"><i class="fa fa-link" aria-hidden="true"></i></a>38. &#x2605;&#x2605;&#x2605;&#x2605; Object.defineProperty&#x6709;&#x4EC0;&#x4E48;&#x7F3A;&#x70B9;</h5>
<pre><code class="lang-JS"><span class="hljs-number">1</span>&#xFF1A;&#x65E0;&#x6CD5;&#x76D1;&#x63A7;&#x5230;&#x6570;&#x7EC4;&#x4E0B;&#x6807;&#x7684;&#x53D8;&#x5316;&#xFF0C;&#x5BFC;&#x81F4;&#x901A;&#x8FC7;&#x6570;&#x7EC4;&#x4E0B;&#x6807;&#x6DFB;&#x52A0;&#x5143;&#x7D20;&#xFF0C;&#x4E0D;&#x80FD;&#x5B9E;&#x65F6;&#x54CD;&#x5E94;&#xFF1B;
<span class="hljs-number">2</span>&#xFF1A;&#x53EA;&#x80FD;&#x52AB;&#x6301;&#x5BF9;&#x8C61;&#x7684;&#x5C5E;&#x6027;&#xFF0C;&#x4ECE;&#x800C;&#x9700;&#x8981;&#x5BF9;&#x6BCF;&#x4E2A;&#x5BF9;&#x8C61;&#xFF0C;&#x6BCF;&#x4E2A;&#x5C5E;&#x6027;&#x8FDB;&#x884C;&#x904D;&#x5386;&#xFF0C;&#x5982;&#x679C;&#xFF0C;&#x5C5E;&#x6027;&#x503C;&#x662F;&#x5BF9;&#x8C61;&#xFF0C;&#x8FD8;&#x9700;&#x8981;&#x6DF1;&#x5EA6;&#x904D;&#x5386;&#x3002;
</code></pre>
<h5 id="39-&#x2605;&#x2605;&#x2605;&#x2605;-axios&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;&#x63CF;&#x8FF0;&#x4F7F;&#x7528;&#x5B83;&#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD;&#x7684;&#x6D41;&#x7A0B;"><a name="39-&#x2605;&#x2605;&#x2605;&#x2605;-axios&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;&#x63CF;&#x8FF0;&#x4F7F;&#x7528;&#x5B83;&#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD;&#x7684;&#x6D41;&#x7A0B;" class="anchor-navigation-ex-anchor" href="#39-&#x2605;&#x2605;&#x2605;&#x2605;-axios&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;&#x63CF;&#x8FF0;&#x4F7F;&#x7528;&#x5B83;&#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD;&#x7684;&#x6D41;&#x7A0B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="39-&#x2605;&#x2605;&#x2605;&#x2605;-axios&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;&#x63CF;&#x8FF0;&#x4F7F;&#x7528;&#x5B83;&#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD;&#x7684;&#x6D41;&#x7A0B;" class="plugin-anchor" href="#39-&#x2605;&#x2605;&#x2605;&#x2605;-axios&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;&#x63CF;&#x8FF0;&#x4F7F;&#x7528;&#x5B83;&#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD;&#x7684;&#x6D41;&#x7A0B;"><i class="fa fa-link" aria-hidden="true"></i></a>39. &#x2605;&#x2605;&#x2605;&#x2605; axios&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;&#x63CF;&#x8FF0;&#x4F7F;&#x7528;&#x5B83;&#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x529F;&#x80FD;&#x7684;&#x6D41;&#x7A0B;?</h5>
<pre><code class="lang-JS">axios &#x662F;&#x8BF7;&#x6C42;&#x540E;&#x53F0;&#x8D44;&#x6E90;&#x7684;&#x6A21;&#x5757;&#x3002; &#x901A;&#x8FC7;npm install axios -S&#x6765;&#x5B89;&#x88C5;&#xFF0C;&#x5728;&#x5927;&#x591A;&#x6570;&#x60C5;&#x51B5;&#x4E0B;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x5C01;&#x88C5;&#x62E6;&#x622A;&#x5668;&#xFF0C;&#x5728;&#x5B9E;&#x73B0;&#x767B;&#x5F55;&#x7684;&#x8FC7;&#x7A0B;&#x4E2D;&#x6211;&#x4EEC;&#x4E00;&#x822C;&#x5728;&#x8BF7;&#x6C42;&#x62E6;&#x622A;&#x5668;&#x4E2D;&#x6765;&#x52A0;&#x5165;token&#xFF0C;&#x5728;&#x54CD;&#x5E94;&#x8BF7;&#x6C42;&#x5668;&#x4E2D;&#x901A;&#x8FC7;&#x5224;&#x65AD;&#x540E;&#x7AEF;&#x8FD4;&#x56DE;&#x7684;&#x72B6;&#x6001;&#x7801;&#x6765;&#x5BF9;&#x8FD4;&#x56DE;&#x7684;&#x6570;&#x636E;&#x8FDB;&#x884C;&#x4E0D;&#x540C;&#x7684;&#x5904;&#x7406;&#x3002;&#x5982;&#x679C;&#x53D1;&#x9001;&#x7684;&#x662F;&#x8DE8;&#x57DF;&#x8BF7;&#x6C42;&#xFF0C;&#x9700;&#x5728;&#x914D;&#x7F6E;&#x6587;&#x4EF6;&#x4E2D; config/index.js &#x8FDB;&#x884C;&#x4EE3;&#x7406;&#x914D;&#x7F6E;&#x3002;
</code></pre>
<h5 id="40-&#x2605;&#x2605;-v-model&#x662F;&#x4EC0;&#x4E48;&#xFF1F;vue&#x4E2D;&#x6807;&#x7B7E;&#x600E;&#x4E48;&#x7ED1;&#x5B9A;&#x4E8B;&#x4EF6;&#xFF1F;"><a name="40-&#x2605;&#x2605;-v-model&#x662F;&#x4EC0;&#x4E48;&#xFF1F;vue&#x4E2D;&#x6807;&#x7B7E;&#x600E;&#x4E48;&#x7ED1;&#x5B9A;&#x4E8B;&#x4EF6;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#40-&#x2605;&#x2605;-v-model&#x662F;&#x4EC0;&#x4E48;&#xFF1F;vue&#x4E2D;&#x6807;&#x7B7E;&#x600E;&#x4E48;&#x7ED1;&#x5B9A;&#x4E8B;&#x4EF6;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="40-&#x2605;&#x2605;-v-model&#x662F;&#x4EC0;&#x4E48;&#xFF1F;vue&#x4E2D;&#x6807;&#x7B7E;&#x600E;&#x4E48;&#x7ED1;&#x5B9A;&#x4E8B;&#x4EF6;&#xFF1F;" class="plugin-anchor" href="#40-&#x2605;&#x2605;-v-model&#x662F;&#x4EC0;&#x4E48;&#xFF1F;vue&#x4E2D;&#x6807;&#x7B7E;&#x600E;&#x4E48;&#x7ED1;&#x5B9A;&#x4E8B;&#x4EF6;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>40. &#x2605;&#x2605; v-model&#x662F;&#x4EC0;&#x4E48;&#xFF1F;Vue&#x4E2D;&#x6807;&#x7B7E;&#x600E;&#x4E48;&#x7ED1;&#x5B9A;&#x4E8B;&#x4EF6;&#xFF1F;</h5>
<pre><code class="lang-JS">v-model&#x662F;&#x4E00;&#x4E2A;&#x8BED;&#x6CD5;&#x7CD6;&#xFF0C;&#x8FD9;&#x4E00;&#x4E2A;&#x6307;&#x4EE4;&#x53EF;&#x4EE5;&#x5206;&#x4E3A;&#x51E0;&#x4E2A;&#x6307;&#x4EE4;&#xFF0C;&#x5B83;&#x5185;&#x90E8;&#x5DF2;&#x7ECF;&#x5E2E;&#x6211;&#x4EEC;&#x5904;&#x7406;&#x6574;&#x5408;&#x4E86;&#x3002;&#x5BF9;&#x4E8E;&#x666E;&#x901A;&#x7684;&#x6587;&#x672C;&#x6846;&#x6765;&#x8BF4;&#xFF0C;v-model = v-bind:value + @input&#x3002;&#x5BF9;&#x5355;&#x9009;&#x6846;&#x548C;&#x590D;&#x9009;&#x6846;&#x6765;&#x8BF4;&#xFF0C;v-model = v-bind:checked + @change&#xFF0C;&#x5E76;&#x4E14;&#x5B83;&#x8FD8;&#x6709;&#x4E00;&#x4E2A;&#x975E;&#x5E38;&#x91CD;&#x8981;&#x7684;&#x529F;&#x80FD;&#xFF0C;&#x5C31;&#x662F;&#x89E3;&#x51B3;&#x7236;&#x5B50;&#x7EC4;&#x4EF6;&#x4E4B;&#x95F4;&#x7684;&#x901A;&#x8BAF;&#x95EE;&#x9898;&#xFF0C;&#x53EF;&#x4EE5;&#x63D0;&#x5347;&#x6211;&#x4EEC;&#x7684;&#x5F00;&#x53D1;&#x6548;&#x7387;&#x3002;&#x5728;vue&#x4E2D;&#x901A;&#x8FC7;&#x4F7F;&#x7528;&lt;v-on:&#x4E8B;&#x4EF6;&#x540D; = &#x51FD;&#x6570;&#x540D;&gt;&#x7684;&#x65B9;&#x5F0F;&#x6765;&#x7ED1;&#x5B9A;&#x4E8B;&#x4EF6;&#x3002;
</code></pre>
<h5 id="41-&#x2605;&#x2605;&#x2605;-&#x8DEF;&#x7531;&#x61D2;&#x52A0;&#x8F7D;"><a name="41-&#x2605;&#x2605;&#x2605;-&#x8DEF;&#x7531;&#x61D2;&#x52A0;&#x8F7D;" class="anchor-navigation-ex-anchor" href="#41-&#x2605;&#x2605;&#x2605;-&#x8DEF;&#x7531;&#x61D2;&#x52A0;&#x8F7D;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="41-&#x2605;&#x2605;&#x2605;-&#x8DEF;&#x7531;&#x61D2;&#x52A0;&#x8F7D;" class="plugin-anchor" href="#41-&#x2605;&#x2605;&#x2605;-&#x8DEF;&#x7531;&#x61D2;&#x52A0;&#x8F7D;"><i class="fa fa-link" aria-hidden="true"></i></a>41. &#x2605;&#x2605;&#x2605; &#x8DEF;&#x7531;&#x61D2;&#x52A0;&#x8F7D;</h5>
<pre><code class="lang-JS">&#x628A;&#x4E0D;&#x540C;&#x8DEF;&#x7531;&#x5BF9;&#x5E94;&#x7684;&#x7EC4;&#x4EF6;&#x5206;&#x5272;&#x6210;&#x4E0D;&#x540C;&#x7684;&#x4EE3;&#x7801;&#x5757;&#xFF0C;&#x7136;&#x540E;&#x5F53;&#x8DEF;&#x7531;&#x88AB;&#x8BBF;&#x95EE;&#x65F6;&#x624D;&#x52A0;&#x8F7D;&#x5BF9;&#x5E94;&#x7684;&#x7EC4;&#x4EF6;&#x5373;&#x4E3A;&#x8DEF;&#x7531;&#x7684;&#x61D2;&#x52A0;&#x8F7D;&#xFF0C;&#x53EF;&#x4EE5;&#x52A0;&#x5FEB;&#x9879;&#x76EE;&#x7684;&#x52A0;&#x8F7D;&#x901F;&#x5EA6;&#xFF0C;&#x63D0;&#x9AD8;&#x6548;&#x7387;&#x3002;&#x901A;&#x8FC7;&#x8FD9;&#x79CD;&#x683C;&#x5F0F;&#x6765;&#x5BFC;&#x5165;&#x7EC4;&#x4EF6;<span class="hljs-keyword">const</span> foo = () =&gt; <span class="hljs-keyword">import</span>(<span class="hljs-string">&apos;./foo.vue&apos;</span>);
</code></pre>
<h5 id="42-&#x2605;&#x2605;&#x2605;&#x2605;-computed&#x548C;watcher&#x7684;&#x533A;&#x522B;&#xFF1F;watch&#x5B9E;&#x73B0;&#x539F;&#x7406;&#xFF1F;watch&#x6709;&#x51E0;&#x79CD;&#x5199;&#x6CD5;&#xFF1F;"><a name="42-&#x2605;&#x2605;&#x2605;&#x2605;-computed&#x548C;watcher&#x7684;&#x533A;&#x522B;&#xFF1F;watch&#x5B9E;&#x73B0;&#x539F;&#x7406;&#xFF1F;watch&#x6709;&#x51E0;&#x79CD;&#x5199;&#x6CD5;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#42-&#x2605;&#x2605;&#x2605;&#x2605;-computed&#x548C;watcher&#x7684;&#x533A;&#x522B;&#xFF1F;watch&#x5B9E;&#x73B0;&#x539F;&#x7406;&#xFF1F;watch&#x6709;&#x51E0;&#x79CD;&#x5199;&#x6CD5;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="42-&#x2605;&#x2605;&#x2605;&#x2605;-computed&#x548C;watcher&#x7684;&#x533A;&#x522B;&#xFF1F;watch&#x5B9E;&#x73B0;&#x539F;&#x7406;&#xFF1F;watch&#x6709;&#x51E0;&#x79CD;&#x5199;&#x6CD5;&#xFF1F;" class="plugin-anchor" href="#42-&#x2605;&#x2605;&#x2605;&#x2605;-computed&#x548C;watcher&#x7684;&#x533A;&#x522B;&#xFF1F;watch&#x5B9E;&#x73B0;&#x539F;&#x7406;&#xFF1F;watch&#x6709;&#x51E0;&#x79CD;&#x5199;&#x6CD5;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>42. &#x2605;&#x2605;&#x2605;&#x2605; computed&#x548C;watcher&#x7684;&#x533A;&#x522B;&#xFF1F;watch&#x5B9E;&#x73B0;&#x539F;&#x7406;&#xFF1F;watch&#x6709;&#x51E0;&#x79CD;&#x5199;&#x6CD5;&#xFF1F;</h5>
<pre><code class="lang-JS">&#x8BA1;&#x7B97;&#x5C5E;&#x6027;computed : 

<span class="hljs-number">1.</span> &#x652F;&#x6301;&#x7F13;&#x5B58;&#xFF0C;&#x53EA;&#x6709;&#x4F9D;&#x8D56;&#x6570;&#x636E;&#x53D1;&#x751F;&#x6539;&#x53D8;&#xFF0C;&#x624D;&#x4F1A;&#x91CD;&#x65B0;&#x8FDB;&#x884C;&#x8BA1;&#x7B97;
<span class="hljs-number">2.</span> &#x4E0D;&#x652F;&#x6301;&#x5F02;&#x6B65;&#xFF0C;&#x5F53;computed&#x5185;&#x6709;&#x5F02;&#x6B65;&#x64CD;&#x4F5C;&#x65F6;&#x65E0;&#x6548;&#xFF0C;&#x65E0;&#x6CD5;&#x76D1;&#x542C;&#x6570;&#x636E;&#x7684;&#x53D8;&#x5316;
<span class="hljs-number">3.</span>computed &#x5C5E;&#x6027;&#x503C;&#x4F1A;&#x9ED8;&#x8BA4;&#x8D70;&#x7F13;&#x5B58;&#xFF0C;&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#x662F;&#x57FA;&#x4E8E;&#x5B83;&#x4EEC;&#x7684;&#x54CD;&#x5E94;&#x5F0F;&#x4F9D;&#x8D56;&#x8FDB;&#x884C;&#x7F13;&#x5B58;&#x7684;&#xFF0C;&#x4E5F;&#x5C31;&#x662F;&#x57FA;&#x4E8E;data&#x4E2D;&#x58F0;&#x660E;&#x8FC7;&#x6216;&#x8005;&#x7236;&#x7EC4;&#x4EF6;&#x4F20;&#x9012;&#x7684;props&#x4E2D;&#x7684;&#x6570;&#x636E;&#x901A;&#x8FC7;&#x8BA1;&#x7B97;&#x5F97;&#x5230;&#x7684;&#x503C;
<span class="hljs-number">4.</span> &#x5982;&#x679C;&#x4E00;&#x4E2A;&#x5C5E;&#x6027;&#x662F;&#x7531;&#x5176;&#x4ED6;&#x5C5E;&#x6027;&#x8BA1;&#x7B97;&#x800C;&#x6765;&#x7684;&#xFF0C;&#x8FD9;&#x4E2A;&#x5C5E;&#x6027;&#x4F9D;&#x8D56;&#x5176;&#x4ED6;&#x5C5E;&#x6027;&#xFF0C;&#x662F;&#x4E00;&#x4E2A;&#x591A;&#x5BF9;&#x4E00;&#x6216;&#x8005;&#x4E00;&#x5BF9;&#x4E00;&#xFF0C;&#x4E00;&#x822C;&#x7528;computed
<span class="hljs-number">5.</span>&#x5982;&#x679C;computed&#x5C5E;&#x6027;&#x5C5E;&#x6027;&#x503C;&#x662F;&#x51FD;&#x6570;&#xFF0C;&#x90A3;&#x4E48;&#x9ED8;&#x8BA4;&#x4F1A;&#x8D70;get&#x65B9;&#x6CD5;&#xFF1B;&#x51FD;&#x6570;&#x7684;&#x8FD4;&#x56DE;&#x503C;&#x5C31;&#x662F;&#x5C5E;&#x6027;&#x7684;&#x5C5E;&#x6027;&#x503C;&#xFF1B;&#x5728;computed&#x4E2D;&#x7684;&#xFF0C;&#x5C5E;&#x6027;&#x90FD;&#x6709;&#x4E00;&#x4E2A;get&#x548C;&#x4E00;&#x4E2A;set&#x65B9;&#x6CD5;&#xFF0C;&#x5F53;&#x6570;&#x636E;&#x53D8;&#x5316;&#x65F6;&#xFF0C;&#x8C03;&#x7528;set&#x65B9;&#x6CD5;&#x3002;

&#x4FA6;&#x542C;&#x5C5E;&#x6027;watch&#xFF1A;

<span class="hljs-number">1.</span> &#x4E0D;&#x652F;&#x6301;&#x7F13;&#x5B58;&#xFF0C;&#x6570;&#x636E;&#x53D8;&#xFF0C;&#x76F4;&#x63A5;&#x4F1A;&#x89E6;&#x53D1;&#x76F8;&#x5E94;&#x7684;&#x64CD;&#x4F5C;&#xFF1B;
<span class="hljs-number">2.</span>watch&#x652F;&#x6301;&#x5F02;&#x6B65;&#xFF1B;
<span class="hljs-number">3.</span>&#x76D1;&#x542C;&#x7684;&#x51FD;&#x6570;&#x63A5;&#x6536;&#x4E24;&#x4E2A;&#x53C2;&#x6570;&#xFF0C;&#x7B2C;&#x4E00;&#x4E2A;&#x53C2;&#x6570;&#x662F;&#x6700;&#x65B0;&#x7684;&#x503C;&#xFF1B;&#x7B2C;&#x4E8C;&#x4E2A;&#x53C2;&#x6570;&#x662F;&#x8F93;&#x5165;&#x4E4B;&#x524D;&#x7684;&#x503C;&#xFF1B;
<span class="hljs-number">4.</span> &#x5F53;&#x4E00;&#x4E2A;&#x5C5E;&#x6027;&#x53D1;&#x751F;&#x53D8;&#x5316;&#x65F6;&#xFF0C;&#x9700;&#x8981;&#x6267;&#x884C;&#x5BF9;&#x5E94;&#x7684;&#x64CD;&#x4F5C;&#xFF1B;&#x4E00;&#x5BF9;&#x591A;&#xFF1B;
<span class="hljs-number">5.</span> &#x76D1;&#x542C;&#x6570;&#x636E;&#x5FC5;&#x987B;&#x662F;data&#x4E2D;&#x58F0;&#x660E;&#x8FC7;&#x6216;&#x8005;&#x7236;&#x7EC4;&#x4EF6;&#x4F20;&#x9012;&#x8FC7;&#x6765;&#x7684;props&#x4E2D;&#x7684;&#x6570;&#x636E;&#xFF0C;&#x5F53;&#x6570;&#x636E;&#x53D8;&#x5316;&#x65F6;&#xFF0C;&#x89E6;&#x53D1;&#x5176;&#x4ED6;&#x64CD;&#x4F5C;&#xFF0C;&#x51FD;&#x6570;&#x6709;&#x4E24;&#x4E2A;&#x53C2;&#x6570;&#xFF0C;
immediate&#xFF1A;&#x7EC4;&#x4EF6;&#x52A0;&#x8F7D;&#x7ACB;&#x5373;&#x89E6;&#x53D1;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#x6267;&#x884C;&#xFF0C;
deep: &#x6DF1;&#x5EA6;&#x76D1;&#x542C;&#xFF0C;&#x4E3A;&#x4E86;&#x53D1;&#x73B0;&#x5BF9;&#x8C61;&#x5185;&#x90E8;&#x503C;&#x7684;&#x53D8;&#x5316;&#xFF0C;&#x590D;&#x6742;&#x7C7B;&#x578B;&#x7684;&#x6570;&#x636E;&#x65F6;&#x4F7F;&#x7528;&#xFF0C;&#x4F8B;&#x5982;&#x6570;&#x7EC4;&#x4E2D;&#x7684;&#x5BF9;&#x8C61;&#x5185;&#x5BB9;&#x7684;&#x6539;&#x53D8;&#xFF0C;&#x6CE8;&#x610F;&#x76D1;&#x542C;&#x6570;&#x7EC4;&#x7684;&#x53D8;&#x52A8;&#x4E0D;&#x9700;&#x8981;&#x8FD9;&#x4E48;&#x505A;&#x3002;
&#x6CE8;&#x610F;&#xFF1A;deep&#x65E0;&#x6CD5;&#x76D1;&#x542C;&#x5230;&#x6570;&#x7EC4;&#x7684;&#x53D8;&#x52A8;&#x548C;&#x5BF9;&#x8C61;&#x7684;&#x65B0;&#x589E;&#xFF0C;&#x53C2;&#x8003;vue&#x6570;&#x7EC4;&#x53D8;&#x5F02;,&#x53EA;&#x6709;&#x4EE5;&#x54CD;&#x5E94;&#x5F0F;&#x7684;&#x65B9;&#x5F0F;&#x89E6;&#x53D1;&#x624D;&#x4F1A;&#x88AB;&#x76D1;&#x542C;&#x5230;&#x3002;

watch&#x5DE5;&#x4F5C;&#x539F;&#x7406;:
watch&#x5728;&#x4E00;&#x5F00;&#x59CB;&#x521D;&#x59CB;&#x5316;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x4F1A;&#x8BFB;&#x53D6;&#x4E00;&#x904D;&#x76D1;&#x542C;&#x7684;&#x6570;&#x636E;&#x7684;&#x503C;&#xFF0C;&#x6B64;&#x65F6;&#x90A3;&#x4E2A;&#x6570;&#x636E;&#x5C31;&#x6536;&#x96C6;&#x5230;watch&#x7684;watcher&#x4E86;&#x7136;&#x540E;&#x4F60;&#x7ED9;watch&#x8BBE;&#x7F6E;&#x7684;handler&#xFF0C;watch &#x4F1A;&#x653E;&#x5165;watcher&#x7684;&#x66F4;&#x65B0;&#x51FD;&#x6570;&#x4E2D;&#xFF0C;&#x5F53;&#x6570;&#x636E;&#x6539;&#x53D8;&#x65F6;&#xFF0C;&#x901A;&#x77E5;watch&#x7684;watcher&#x8FDB;&#x884C;&#x66F4;&#x65B0;&#xFF0C;&#x4E8E;&#x662F;&#x4F60;&#x8BBE;&#x7F6E;&#x7684;handler&#x5C31;&#x88AB;&#x8C03;&#x7528;&#x4E86;&#x3002;
</code></pre>
<h5 id="43-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;-computed-&#x7684;&#x539F;&#x7406;&#xFF0C;&#x600E;&#x4E48;&#x8FFD;&#x8E2A;&#x5230;&#x5B83;&#x7684;&#x4F9D;&#x8D56;&#x7684;&#xFF1F;&#x8FD8;&#x662F;&#x600E;&#x4E48;&#x786E;&#x5B9A;&#x662F;&#x4ED6;&#x7684;&#x4F9D;&#x8D56;&#x53D8;&#x66F4;-&#x4ED6;&#x624D;&#x66F4;&#x65B0;"><a name="43-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;-computed-&#x7684;&#x539F;&#x7406;&#xFF0C;&#x600E;&#x4E48;&#x8FFD;&#x8E2A;&#x5230;&#x5B83;&#x7684;&#x4F9D;&#x8D56;&#x7684;&#xFF1F;&#x8FD8;&#x662F;&#x600E;&#x4E48;&#x786E;&#x5B9A;&#x662F;&#x4ED6;&#x7684;&#x4F9D;&#x8D56;&#x53D8;&#x66F4;-&#x4ED6;&#x624D;&#x66F4;&#x65B0;" class="anchor-navigation-ex-anchor" href="#43-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;-computed-&#x7684;&#x539F;&#x7406;&#xFF0C;&#x600E;&#x4E48;&#x8FFD;&#x8E2A;&#x5230;&#x5B83;&#x7684;&#x4F9D;&#x8D56;&#x7684;&#xFF1F;&#x8FD8;&#x662F;&#x600E;&#x4E48;&#x786E;&#x5B9A;&#x662F;&#x4ED6;&#x7684;&#x4F9D;&#x8D56;&#x53D8;&#x66F4;-&#x4ED6;&#x624D;&#x66F4;&#x65B0;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="43-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;-computed-&#x7684;&#x539F;&#x7406;&#xFF0C;&#x600E;&#x4E48;&#x8FFD;&#x8E2A;&#x5230;&#x5B83;&#x7684;&#x4F9D;&#x8D56;&#x7684;&#xFF1F;&#x8FD8;&#x662F;&#x600E;&#x4E48;&#x786E;&#x5B9A;&#x662F;&#x4ED6;&#x7684;&#x4F9D;&#x8D56;&#x53D8;&#x66F4;-&#x4ED6;&#x624D;&#x66F4;&#x65B0;" class="plugin-anchor" href="#43-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;-computed-&#x7684;&#x539F;&#x7406;&#xFF0C;&#x600E;&#x4E48;&#x8FFD;&#x8E2A;&#x5230;&#x5B83;&#x7684;&#x4F9D;&#x8D56;&#x7684;&#xFF1F;&#x8FD8;&#x662F;&#x600E;&#x4E48;&#x786E;&#x5B9A;&#x662F;&#x4ED6;&#x7684;&#x4F9D;&#x8D56;&#x53D8;&#x66F4;-&#x4ED6;&#x624D;&#x66F4;&#x65B0;"><i class="fa fa-link" aria-hidden="true"></i></a>43. &#x2605;&#x2605;&#x2605; Vue&#x4E2D; computed &#x7684;&#x539F;&#x7406;&#xFF0C;&#x600E;&#x4E48;&#x8FFD;&#x8E2A;&#x5230;&#x5B83;&#x7684;&#x4F9D;&#x8D56;&#x7684;&#xFF1F;&#x8FD8;&#x662F;&#x600E;&#x4E48;&#x786E;&#x5B9A;&#x662F;&#x4ED6;&#x7684;&#x4F9D;&#x8D56;&#x53D8;&#x66F4; &#x4ED6;&#x624D;&#x66F4;&#x65B0;</h5>
<pre><code class="lang-JS"><span class="hljs-comment">// &#x7B54;&#x6848;&#xFF1A;</span>
</code></pre>
<h5 id="44-&#x2605;&#x2605;&#x2605;&#x2605;-&#x5982;&#x679C;&#x4F60;&#x662F;leader&#xFF0C;&#x505A;&#x7BA1;&#x7406;&#x7CFB;&#x7EDF;&#x9879;&#x76EE;-vue&#x548C;react-&#x600E;&#x4E48;&#x9009;&#x62E9;&#xFF1F;"><a name="44-&#x2605;&#x2605;&#x2605;&#x2605;-&#x5982;&#x679C;&#x4F60;&#x662F;leader&#xFF0C;&#x505A;&#x7BA1;&#x7406;&#x7CFB;&#x7EDF;&#x9879;&#x76EE;-vue&#x548C;react-&#x600E;&#x4E48;&#x9009;&#x62E9;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#44-&#x2605;&#x2605;&#x2605;&#x2605;-&#x5982;&#x679C;&#x4F60;&#x662F;leader&#xFF0C;&#x505A;&#x7BA1;&#x7406;&#x7CFB;&#x7EDF;&#x9879;&#x76EE;-vue&#x548C;react-&#x600E;&#x4E48;&#x9009;&#x62E9;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="44-&#x2605;&#x2605;&#x2605;&#x2605;-&#x5982;&#x679C;&#x4F60;&#x662F;leader&#xFF0C;&#x505A;&#x7BA1;&#x7406;&#x7CFB;&#x7EDF;&#x9879;&#x76EE;-vue&#x548C;react-&#x600E;&#x4E48;&#x9009;&#x62E9;&#xFF1F;" class="plugin-anchor" href="#44-&#x2605;&#x2605;&#x2605;&#x2605;-&#x5982;&#x679C;&#x4F60;&#x662F;leader&#xFF0C;&#x505A;&#x7BA1;&#x7406;&#x7CFB;&#x7EDF;&#x9879;&#x76EE;-vue&#x548C;react-&#x600E;&#x4E48;&#x9009;&#x62E9;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>44. &#x2605;&#x2605;&#x2605;&#x2605; &#x5982;&#x679C;&#x4F60;&#x662F;leader&#xFF0C;&#x505A;&#x7BA1;&#x7406;&#x7CFB;&#x7EDF;&#x9879;&#x76EE; Vue&#x548C;React &#x600E;&#x4E48;&#x9009;&#x62E9;&#xFF1F;</h5>
<pre><code class="lang-JS"> &#x8BC4;&#x4F30;&#x9879;&#x76EE;&#x6210;&#x5458;&#x7684;&#x6C34;&#x5E73;&#xFF0C;&#x5982;&#x679C;&#x6210;&#x5458;js&#x57FA;&#x7840;&#x8F83;&#x597D;&#x3001;&#x7F16;&#x7801;&#x80FD;&#x529B;&#x8F83;&#x5F3A;&#x5219;&#x9009;&#x62E9;React&#xFF0C;&#x5426;&#x5219;Vue&#x3002;
 &#x8BC4;&#x4F30;&#x7CFB;&#x7EDF;&#x7684;&#x5927;&#x5C0F;&#xFF0C;&#x5982;&#x679C;&#x60F3;&#x6784;&#x5EFA;&#x751F;&#x6001;&#x7CFB;&#x7EDF;&#xFF0C;&#x5219;&#x9009;&#x62E9;React&#xFF0C;&#x5982;&#x679C;&#x8981;&#x6C42;&#x800C;&#x5FEB;&#xFF0C;&#x7B80;&#x5355;&#x548C;&#x201C;&#x80FD;&#x7528;&#x5C31;&#x884C;&quot;,&#x5219;&#x9009;&#x62E9;Vue&#x3002;
 &#x8BC4;&#x4F30;&#x7CFB;&#x7EDF;&#x8FD0;&#x884C;&#x73AF;&#x5883;&#xFF0C;&#x5982;&#x679C;&#x4F60;&#x60F3;&#x8981;&#x4E00;&#x4E2A;&#x540C;&#x65F6;&#x9002;&#x7528;&#x4E8E;Web&#x7AEF;&#x548C;&#x539F;&#x751F;APP&#x7684;&#x6846;&#x67B6;&#xFF0C;&#x8BF7;&#x9009;&#x62E9;React(RN)&#x3002;
</code></pre>
<h5 id="45-&#x2605;&#x2605;&#x2605;-vuex&#x7684;&#x7F3A;&#x70B9;"><a name="45-&#x2605;&#x2605;&#x2605;-vuex&#x7684;&#x7F3A;&#x70B9;" class="anchor-navigation-ex-anchor" href="#45-&#x2605;&#x2605;&#x2605;-vuex&#x7684;&#x7F3A;&#x70B9;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="45-&#x2605;&#x2605;&#x2605;-vuex&#x7684;&#x7F3A;&#x70B9;" class="plugin-anchor" href="#45-&#x2605;&#x2605;&#x2605;-vuex&#x7684;&#x7F3A;&#x70B9;"><i class="fa fa-link" aria-hidden="true"></i></a>45. &#x2605;&#x2605;&#x2605; Vuex&#x7684;&#x7F3A;&#x70B9;</h5>
<pre><code class="lang-JS">&#x5982;&#x679C;&#x60A8;&#x4E0D;&#x6253;&#x7B97;&#x5F00;&#x53D1;&#x5927;&#x578B;&#x5355;&#x9875;&#x5E94;&#x7528;&#xFF0C;&#x4F7F;&#x7528; Vuex &#x53EF;&#x80FD;&#x662F;&#x7E41;&#x7410;&#x5197;&#x4F59;&#x7684;&#xFF0C;&#x5E76;&#x4E14;state&#x4E2D;&#x7684;&#x503C;&#x4F1A;&#x4F34;&#x968F;&#x7740;&#x6D4F;&#x89C8;&#x5668;&#x7684;&#x5237;&#x65B0;&#x800C;&#x521D;&#x59CB;&#x5316;&#xFF0C;&#x65E0;&#x7F13;&#x5B58;&#x3002;
</code></pre>
<h5 id="46-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x548C;react&#x533A;&#x522B;"><a name="46-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x548C;react&#x533A;&#x522B;" class="anchor-navigation-ex-anchor" href="#46-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x548C;react&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="46-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x548C;react&#x533A;&#x522B;" class="plugin-anchor" href="#46-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x548C;react&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a>46. &#x2605;&#x2605;&#x2605;&#x2605; Vue&#x548C;React&#x533A;&#x522B;</h5>
<pre><code class="lang-JS"><span class="hljs-number">1</span>&#xFF1A;Vue &#x4F7F;&#x7528;&#x7684;&#x662F; web &#x5F00;&#x53D1;&#x8005;&#x66F4;&#x719F;&#x6089;&#x7684;&#x6A21;&#x677F;&#x4E0E;&#x7279;&#x6027;&#xFF0C;Vue&#x7684;API&#x8DDF;&#x4F20;&#x7EDF;web&#x5F00;&#x53D1;&#x8005;&#x719F;&#x6089;&#x7684;&#x6A21;&#x677F;&#x5951;&#x5408;&#x5EA6;&#x66F4;&#x9AD8;&#xFF0C;&#x6BD4;&#x5982;Vue&#x7684;&#x5355;&#x6587;&#x4EF6;&#x7EC4;&#x4EF6;&#x662F;&#x4EE5;&#x6A21;&#x677F;+JavaScript+CSS&#x7684;&#x7EC4;&#x5408;&#x6A21;&#x5F0F;&#x5448;&#x73B0;&#xFF0C;&#x5B83;&#x8DDF;web&#x73B0;&#x6709;&#x7684;HTML&#x3001;JavaScript&#x3001;CSS&#x80FD;&#x591F;&#x66F4;&#x597D;&#x5730;&#x914D;&#x5408;&#x3002;React &#x7684;&#x7279;&#x8272;&#x5728;&#x4E8E;&#x51FD;&#x6570;&#x5F0F;&#x7F16;&#x7A0B;&#x7684;&#x7406;&#x5FF5;&#x548C;&#x4E30;&#x5BCC;&#x7684;&#x6280;&#x672F;&#x9009;&#x578B;&#xFF0C;Vue&#x66F4;&#x52A0;&#x6CE8;&#x91CD;web&#x5F00;&#x53D1;&#x8005;&#x7684;&#x4E60;&#x60EF;&#x3002;
<span class="hljs-number">2</span>&#xFF1A;Vue&#x8DDF;React&#x7684;&#x6700;&#x5927;&#x533A;&#x522B;&#x5728;&#x4E8E;&#x6570;&#x636E;&#x7684;reactivity&#xFF0C;&#x5C31;&#x662F;&#x53CD;&#x5E94;&#x5F0F;&#x7CFB;&#x7EDF;&#x4E0A;&#x3002;Vue&#x63D0;&#x4F9B;&#x53CD;&#x5E94;&#x5F0F;&#x7684;&#x6570;&#x636E;&#xFF0C;&#x5F53;&#x6570;&#x636E;&#x6539;&#x52A8;&#x65F6;&#xFF0C;&#x754C;&#x9762;&#x5C31;&#x4F1A;&#x81EA;&#x52A8;&#x66F4;&#x65B0;&#xFF0C;&#x800C;React&#x91CC;&#x9762;&#x9700;&#x8981;&#x8C03;&#x7528;&#x65B9;&#x6CD5;SetState&#x3002;&#x6211;&#x628A;&#x4E24;&#x8005;&#x5206;&#x522B;&#x79F0;&#x4E3A;Push-based&#x548C;Pull-based
</code></pre>
<h5 id="47-&#x2605;&#x2605;&#x2605;-vue&#x8DEF;&#x7531;&#x4F20;&#x53C2;&#xFF0C;&#x5237;&#x65B0;&#x540E;&#x8FD8;&#x6709;&#x5417;"><a name="47-&#x2605;&#x2605;&#x2605;-vue&#x8DEF;&#x7531;&#x4F20;&#x53C2;&#xFF0C;&#x5237;&#x65B0;&#x540E;&#x8FD8;&#x6709;&#x5417;" class="anchor-navigation-ex-anchor" href="#47-&#x2605;&#x2605;&#x2605;-vue&#x8DEF;&#x7531;&#x4F20;&#x53C2;&#xFF0C;&#x5237;&#x65B0;&#x540E;&#x8FD8;&#x6709;&#x5417;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="47-&#x2605;&#x2605;&#x2605;-vue&#x8DEF;&#x7531;&#x4F20;&#x53C2;&#xFF0C;&#x5237;&#x65B0;&#x540E;&#x8FD8;&#x6709;&#x5417;" class="plugin-anchor" href="#47-&#x2605;&#x2605;&#x2605;-vue&#x8DEF;&#x7531;&#x4F20;&#x53C2;&#xFF0C;&#x5237;&#x65B0;&#x540E;&#x8FD8;&#x6709;&#x5417;"><i class="fa fa-link" aria-hidden="true"></i></a>47. &#x2605;&#x2605;&#x2605; Vue&#x8DEF;&#x7531;&#x4F20;&#x53C2;&#xFF0C;&#x5237;&#x65B0;&#x540E;&#x8FD8;&#x6709;&#x5417;</h5>
<pre><code class="lang-JS">&#x901A;&#x8FC7;params&#x4F20;&#x53C2;&#x4F1A;&#x51FA;&#x73B0;&#x53C2;&#x6570;&#x4E22;&#x5931;&#x7684;&#x60C5;&#x51B5;&#xFF0C;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;query&#x7684;&#x4F20;&#x53C2;&#x65B9;&#x5F0F;&#x6216;&#x8005;&#x5728;&#x8DEF;&#x7531;&#x5339;&#x914D;&#x89C4;&#x5219;&#x52A0;&#x5165;&#x5360;&#x4F4D;&#x7B26;&#x5373;&#x53EF;&#x4EE5;&#x89E3;&#x51B3;&#x53C2;&#x6570;&#x4E22;&#x5931;&#x7684;&#x60C5;&#x51B5;&#x3002;
</code></pre>
<h5 id="48-&#x2605;&#x2605;&#x2605;-vue&#x6DF1;&#x5C42;&#x6B21;&#x5D4C;&#x5957;&#x4F20;&#x503C;&#x65B9;&#x6CD5;"><a name="48-&#x2605;&#x2605;&#x2605;-vue&#x6DF1;&#x5C42;&#x6B21;&#x5D4C;&#x5957;&#x4F20;&#x503C;&#x65B9;&#x6CD5;" class="anchor-navigation-ex-anchor" href="#48-&#x2605;&#x2605;&#x2605;-vue&#x6DF1;&#x5C42;&#x6B21;&#x5D4C;&#x5957;&#x4F20;&#x503C;&#x65B9;&#x6CD5;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="48-&#x2605;&#x2605;&#x2605;-vue&#x6DF1;&#x5C42;&#x6B21;&#x5D4C;&#x5957;&#x4F20;&#x503C;&#x65B9;&#x6CD5;" class="plugin-anchor" href="#48-&#x2605;&#x2605;&#x2605;-vue&#x6DF1;&#x5C42;&#x6B21;&#x5D4C;&#x5957;&#x4F20;&#x503C;&#x65B9;&#x6CD5;"><i class="fa fa-link" aria-hidden="true"></i></a>48. &#x2605;&#x2605;&#x2605; Vue&#x6DF1;&#x5C42;&#x6B21;&#x5D4C;&#x5957;&#x4F20;&#x503C;&#x65B9;&#x6CD5;</h5>
<pre><code class="lang-JS">&#x5229;&#x7528;$attrs &#x548C; $listeners
</code></pre>
<h5 id="49-&#x2605;&#x2605;&#x2605;-vue&#x7EC4;&#x4EF6;&#x5982;&#x4F55;&#x5F15;&#x5165;&#x4F7F;&#x7528;"><a name="49-&#x2605;&#x2605;&#x2605;-vue&#x7EC4;&#x4EF6;&#x5982;&#x4F55;&#x5F15;&#x5165;&#x4F7F;&#x7528;" class="anchor-navigation-ex-anchor" href="#49-&#x2605;&#x2605;&#x2605;-vue&#x7EC4;&#x4EF6;&#x5982;&#x4F55;&#x5F15;&#x5165;&#x4F7F;&#x7528;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="49-&#x2605;&#x2605;&#x2605;-vue&#x7EC4;&#x4EF6;&#x5982;&#x4F55;&#x5F15;&#x5165;&#x4F7F;&#x7528;" class="plugin-anchor" href="#49-&#x2605;&#x2605;&#x2605;-vue&#x7EC4;&#x4EF6;&#x5982;&#x4F55;&#x5F15;&#x5165;&#x4F7F;&#x7528;"><i class="fa fa-link" aria-hidden="true"></i></a>49. &#x2605;&#x2605;&#x2605; Vue&#x7EC4;&#x4EF6;&#x5982;&#x4F55;&#x5F15;&#x5165;&#x4F7F;&#x7528;</h5>
<pre><code class="lang-JS"><span class="hljs-number">1.</span> &#x5B9A;&#x4E49;&#x7EC4;&#x4EF6;&#x5E76;&#x629B;&#x51FA;
<span class="hljs-number">2.</span> <span class="hljs-keyword">import</span>&#x5F15;&#x5165;&#xFF0C;&#x5E76;&#x5728;component&#x91CC;&#x9762;&#x5B9A;&#x4E49;
<span class="hljs-number">3.</span> &#x4F7F;&#x7528;&#x7EC4;&#x4EF6;&#xFF08;&#x6CE8;&#x610F;&#x9996;&#x5B57;&#x6BCD;&#x5927;&#x5199;&#xFF09;
</code></pre>
<h5 id="50-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x8DEF;&#x7531;&#x5B9E;&#x73B0;&#x7684;&#x5E95;&#x5C42;&#x539F;&#x7406;"><a name="50-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x8DEF;&#x7531;&#x5B9E;&#x73B0;&#x7684;&#x5E95;&#x5C42;&#x539F;&#x7406;" class="anchor-navigation-ex-anchor" href="#50-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x8DEF;&#x7531;&#x5B9E;&#x73B0;&#x7684;&#x5E95;&#x5C42;&#x539F;&#x7406;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="50-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x8DEF;&#x7531;&#x5B9E;&#x73B0;&#x7684;&#x5E95;&#x5C42;&#x539F;&#x7406;" class="plugin-anchor" href="#50-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x8DEF;&#x7531;&#x5B9E;&#x73B0;&#x7684;&#x5E95;&#x5C42;&#x539F;&#x7406;"><i class="fa fa-link" aria-hidden="true"></i></a>50. &#x2605;&#x2605;&#x2605;&#x2605; Vue&#x8DEF;&#x7531;&#x5B9E;&#x73B0;&#x7684;&#x5E95;&#x5C42;&#x539F;&#x7406;</h5>
<pre><code class="lang-JS">&#x5728;Vue&#x4E2D;&#x5229;&#x7528;&#x6570;&#x636E;&#x52AB;&#x6301;defineProperty&#x5728;&#x539F;&#x578B;prototype&#x4E0A;&#x521D;&#x59CB;&#x5316;&#x4E86;&#x4E00;&#x4E9B;getter,&#x5206;&#x522B;&#x662F;router&#x4EE3;&#x8868;&#x5F53;&#x524D;Router&#x7684;&#x5B9E;&#x4F8B; &#x3001; router&#x4EE3;&#x8868;&#x5F53;&#x524D;Router&#x7684;&#x5B9E;&#x4F8B;&#x3001;router&#x4EE3;&#x8868;&#x5F53;&#x524D;Router&#x7684;&#x5B9E;&#x4F8B;&#x3001;route &#x4EE3;&#x8868;&#x5F53;&#x524D;Router&#x7684;&#x4FE1;&#x606F;&#x3002;&#x5728;install&#x4E2D;&#x4E5F;&#x5168;&#x5C40;&#x6CE8;&#x518C;&#x4E86;router-view,router-link,&#x5176;&#x4E2D;&#x7684;Vue.util.defineReactive, &#x8FD9;&#x662F;Vue&#x91CC;&#x9762;&#x89C2;&#x5BDF;&#x8005;&#x52AB;&#x6301;&#x6570;&#x636E;&#x7684;&#x65B9;&#x6CD5;&#xFF0C;&#x52AB;&#x6301;_route&#xFF0C;&#x5F53;_route&#x89E6;&#x53D1;setter&#x65B9;&#x6CD5;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x5219;&#x4F1A;&#x901A;&#x77E5;&#x5230;&#x4F9D;&#x8D56;&#x7684;&#x7EC4;&#x4EF6;&#x3002;

&#x63A5;&#x4E0B;&#x6765;&#x5728;init&#x4E2D;&#xFF0C;&#x4F1A;&#x6302;&#x8F7D;&#x5224;&#x65AD;&#x662F;&#x8DEF;&#x7531;&#x7684;&#x6A21;&#x5F0F;&#xFF0C;&#x662F;history&#x6216;&#x8005;&#x662F;hash,&#x70B9;&#x51FB;&#x884C;&#x4E3A;&#x6309;&#x94AE;&#xFF0C;&#x8C03;&#x7528;hashchange&#x6216;&#x8005;popstate&#x7684;&#x540C;&#x65F6;&#x66F4;_route,_route&#x7684;&#x66F4;&#x65B0;&#x4F1A;&#x89E6;&#x53D1;route-view&#x7684;&#x91CD;&#x65B0;&#x6E32;&#x67D3;&#x3002;
</code></pre>
<h5 id="51-&#x2605;&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x5C01;&#x88C5;&#x4E00;&#x4E2A;&#x901A;&#x7528;&#x7EC4;&#x4EF6;"><a name="51-&#x2605;&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x5C01;&#x88C5;&#x4E00;&#x4E2A;&#x901A;&#x7528;&#x7EC4;&#x4EF6;" class="anchor-navigation-ex-anchor" href="#51-&#x2605;&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x5C01;&#x88C5;&#x4E00;&#x4E2A;&#x901A;&#x7528;&#x7EC4;&#x4EF6;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="51-&#x2605;&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x5C01;&#x88C5;&#x4E00;&#x4E2A;&#x901A;&#x7528;&#x7EC4;&#x4EF6;" class="plugin-anchor" href="#51-&#x2605;&#x2605;&#x2605;&#x2605;-&#x5982;&#x4F55;&#x5C01;&#x88C5;&#x4E00;&#x4E2A;&#x901A;&#x7528;&#x7EC4;&#x4EF6;"><i class="fa fa-link" aria-hidden="true"></i></a>51. &#x2605;&#x2605;&#x2605;&#x2605; &#x5982;&#x4F55;&#x5C01;&#x88C5;&#x4E00;&#x4E2A;&#x901A;&#x7528;&#x7EC4;&#x4EF6;</h5>
<pre><code class="lang-JS">&#x901A;&#x7528;&#x7EC4;&#x4EF6;&#x7684;&#x5C01;&#x88C5;&#x5C31;&#x662F;&#x5BF9;&#x53EF;&#x590D;&#x7528;&#x7EC4;&#x4EF6;&#x7684;&#x89E3;&#x8026;&#x548C;&#x6837;&#x5F0F;&#x590D;&#x7528;&#xFF0C;&#x4E3A;&#x4E86;&#x89E3;&#x8026;&#x4E00;&#x822C;&#x6570;&#x636E;&#x90FD;&#x662F;&#x901A;&#x8FC7;&#x7236;&#x7EC4;&#x4EF6;&#x4F20;&#x9012;&#x8FC7;&#x6765;&#xFF0C;&#x5728;&#x5B50;&#x7EC4;&#x4EF6;&#x4E2D;&#x8FDB;&#x884C;&#x6570;&#x636E;&#x5904;&#x7406;&#xFF0C;&#x5BF9;&#x4E8E;&#x4E00;&#x4E9B;&#x8F83;&#x4E3A;&#x590D;&#x6742;&#x7684;&#x6570;&#x636E;&#x53EF;&#x80FD;&#x8FD8;&#x9700;&#x8981;&#x505A;&#x6570;&#x636E;&#x9A8C;&#x8BC1;&#xFF0C;&#x4E3A;&#x4E86;&#x907F;&#x514D;&#x9AD8;&#x8026;&#x5408;&#xFF0C;&#x903B;&#x8F91;&#x6700;&#x597D;&#x653E;&#x5728;&#x7236;&#x7EC4;&#x4EF6;&#x4E2D;&#xFF0C;&#x901A;&#x8FC7;&#x81EA;&#x5B9A;&#x4E49;&#x4E8B;&#x4EF6;&#x5C06;&#x6570;&#x636E;&#x56DE;&#x4F20;&#xFF0C;&#x5B50;&#x7EC4;&#x4EF6;&#x53EA;&#x662F;&#x4E00;&#x4E2A;&#x627F;&#x8F7D;&#x4F53;&#xFF0C;&#x8FD9;&#x6837;&#x65E2;&#x964D;&#x4F4E;&#x8026;&#x5408;&#xFF0C;&#x4FDD;&#x8BC1;&#x5B50;&#x7EC4;&#x4EF6;&#x4E2D;&#x6570;&#x636E;&#x548C;&#x903B;&#x8F91;&#x4E0D;&#x4F1A;&#x6DF7;&#x4E71;&#x3002;&#x5982;&#x679C;&#x540C;&#x4E00;&#x7EC4;&#x4EF6;&#x9700;&#x8981;&#x9002;&#x5E94;&#x4E0D;&#x540C;&#x9700;&#x6C42;&#x65F6;&#xFF0C;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x914D;&#x5408;slot&#x6765;&#x4F7F;&#x7528;&#xFF0C;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x5177;&#x540D;&#x63D2;&#x69FD;&#x7075;&#x6D3B;&#x5730;&#x89E3;&#x51B3;&#x4E86;&#x4E0D;&#x540C;&#x573A;&#x666F;&#x540C;&#x4E00;&#x7EC4;&#x4EF6;&#x4E0D;&#x540C;&#x914D;&#x7F6E;&#x7684;&#x95EE;&#x9898;&#x3002;
</code></pre>
<h5 id="52-&#x2605;&#x2605;-vue-&#x751F;&#x547D;&#x5468;&#x671F;&#x901A;&#x5E38;&#x4F7F;&#x7528;&#x54EA;&#x4E9B;"><a name="52-&#x2605;&#x2605;-vue-&#x751F;&#x547D;&#x5468;&#x671F;&#x901A;&#x5E38;&#x4F7F;&#x7528;&#x54EA;&#x4E9B;" class="anchor-navigation-ex-anchor" href="#52-&#x2605;&#x2605;-vue-&#x751F;&#x547D;&#x5468;&#x671F;&#x901A;&#x5E38;&#x4F7F;&#x7528;&#x54EA;&#x4E9B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="52-&#x2605;&#x2605;-vue-&#x751F;&#x547D;&#x5468;&#x671F;&#x901A;&#x5E38;&#x4F7F;&#x7528;&#x54EA;&#x4E9B;" class="plugin-anchor" href="#52-&#x2605;&#x2605;-vue-&#x751F;&#x547D;&#x5468;&#x671F;&#x901A;&#x5E38;&#x4F7F;&#x7528;&#x54EA;&#x4E9B;"><i class="fa fa-link" aria-hidden="true"></i></a>52. &#x2605;&#x2605; Vue &#x751F;&#x547D;&#x5468;&#x671F;&#x901A;&#x5E38;&#x4F7F;&#x7528;&#x54EA;&#x4E9B;</h5>
<pre><code class="lang-JS">&#x5E38;&#x7528;&#x7684;&#x751F;&#x547D;&#x5468;&#x671F;&#x6709;&#xFF0C;beforeCreate&#xFF0C;created&#xFF0C;beforeMount&#xFF0C;mounted&#xFF0C;beforeUpdate&#xFF0C;updated&#xFF0C;beforeDestroy&#xFF0C;destroyed
</code></pre>
<h5 id="53-&#x2605;&#x2605;-vue-&#x6DF1;&#x5C42;&#x6B21;&#x7684;&#x7EC4;&#x4EF6;&#x600E;&#x4E48;&#x548C;&#x7236;&#x7EC4;&#x4EF6;&#x901A;&#x8BAF;"><a name="53-&#x2605;&#x2605;-vue-&#x6DF1;&#x5C42;&#x6B21;&#x7684;&#x7EC4;&#x4EF6;&#x600E;&#x4E48;&#x548C;&#x7236;&#x7EC4;&#x4EF6;&#x901A;&#x8BAF;" class="anchor-navigation-ex-anchor" href="#53-&#x2605;&#x2605;-vue-&#x6DF1;&#x5C42;&#x6B21;&#x7684;&#x7EC4;&#x4EF6;&#x600E;&#x4E48;&#x548C;&#x7236;&#x7EC4;&#x4EF6;&#x901A;&#x8BAF;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="53-&#x2605;&#x2605;-vue-&#x6DF1;&#x5C42;&#x6B21;&#x7684;&#x7EC4;&#x4EF6;&#x600E;&#x4E48;&#x548C;&#x7236;&#x7EC4;&#x4EF6;&#x901A;&#x8BAF;" class="plugin-anchor" href="#53-&#x2605;&#x2605;-vue-&#x6DF1;&#x5C42;&#x6B21;&#x7684;&#x7EC4;&#x4EF6;&#x600E;&#x4E48;&#x548C;&#x7236;&#x7EC4;&#x4EF6;&#x901A;&#x8BAF;"><i class="fa fa-link" aria-hidden="true"></i></a>53. &#x2605;&#x2605; Vue &#x6DF1;&#x5C42;&#x6B21;&#x7684;&#x7EC4;&#x4EF6;&#x600E;&#x4E48;&#x548C;&#x7236;&#x7EC4;&#x4EF6;&#x901A;&#x8BAF;</h5>
<p>1&#x3001;&#x4F7F;&#x7528;$attrs&#x548C;$listeners</p>
<pre><code class="lang-js">Vue.component(<span class="hljs-string">&apos;C&apos;</span>, {
  template: <span class="hljs-string">`
    &lt;div&gt;
      &lt;p&gt;&#x6211;&#x662F;C&#x7EC4;&#x4EF6;&lt;/p&gt;
      &lt;input 
        type=&apos;text&apos; 
        v-model=&apos;$attrs.msgc&apos; 
        @input=&apos;$emit(&quot;getC&quot;, $attrs.msgc)&apos; 
      /&gt;
    &lt;/div&gt;
    `</span>
})

Vue.component(<span class="hljs-string">&apos;B&apos;</span>, {
  <span class="hljs-comment">/**
    &#x7ED9;C&#x7EC4;&#x4EF6;&#x7ED1;&#x5B9A;$attrs&#x5C5E;&#x6027;&#x548C;$listeners&#x4E8B;&#x4EF6;&#xFF0C;C&#x7EC4;&#x4EF6;&#x53EF;&#x4EE5;&#x76F4;&#x63A5;&#x83B7;&#x53D6;&#x5230;A&#x7EC4;&#x4EF6;&#x4E2D;&#x4F20;&#x9012;&#x4E0B;&#x6765;&#x7684;props&#xFF08;&#x9664;&#x4E86;B&#x7EC4;&#x4EF6;&#x4E2D;props&#x58F0;&#x660E;&#x7684;&#xFF09;
  */</span>
  template: <span class="hljs-string">`
    &lt;div&gt;
      &lt;p&gt;&#x6211;&#x662F;B&#x7EC4;&#x4EF6;&lt;/p&gt;
      &lt;input 
        type=&apos;text&apos; 
        v-model=&apos;mymsg1&apos; 
        @input=&quot;$emit(&apos;getChild&apos;, mymsg1)&quot;
      /&gt;
      &lt;C v-bind=&apos;$attrs&apos; v-on=&apos;$listeners&apos;/&gt;
    &lt;/div&gt;
  `</span>,
  props: [<span class="hljs-string">&apos;msg1&apos;</span>],
  data () {
    <span class="hljs-keyword">return</span> {
      mymsg1: <span class="hljs-keyword">this</span>.msg1
    }
  }
})

Vue.component(<span class="hljs-string">&apos;A&apos;</span>, {
  template: <span class="hljs-string">`
    &lt;div id=&apos;app&apos;&gt;
      &lt;p&gt;&#x6211;&#x662F;A&#x7EC4;&#x4EF6;&lt;/p&gt;
      &lt;B 
        :msg1=&apos;msg1&apos; 
        :msgc=&apos;msgc&apos; 
        @getChild=&apos;getChild&apos;
        @getC=&apos;getC&apos;
      /&gt;
    &lt;/div&gt;
  `</span>,
  data () {
    <span class="hljs-keyword">return</span> {
      msg1: <span class="hljs-string">&apos;A&apos;</span>,
      msgc: <span class="hljs-string">&apos;hello c!&apos;</span>
    }
  },
  methods: {
    getChild (val) {
      <span class="hljs-built_in">console</span>.log( val )
    },
    getC (val) {
      <span class="hljs-built_in">console</span>.log( val )
    }
  }
})

<span class="hljs-keyword">const</span> app = <span class="hljs-keyword">new</span> Vue({
  el: <span class="hljs-string">&apos;#app&apos;</span>,
  template: <span class="hljs-string">`
      &lt;A /&gt;  
  `</span>
})
</code></pre>
<h5 id="54-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue-&#x54CD;&#x5E94;&#x5F0F;&#x539F;&#x7406;"><a name="54-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue-&#x54CD;&#x5E94;&#x5F0F;&#x539F;&#x7406;" class="anchor-navigation-ex-anchor" href="#54-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue-&#x54CD;&#x5E94;&#x5F0F;&#x539F;&#x7406;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="54-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue-&#x54CD;&#x5E94;&#x5F0F;&#x539F;&#x7406;" class="plugin-anchor" href="#54-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue-&#x54CD;&#x5E94;&#x5F0F;&#x539F;&#x7406;"><i class="fa fa-link" aria-hidden="true"></i></a>54. &#x2605;&#x2605;&#x2605;&#x2605;&#x2605; Vue &#x54CD;&#x5E94;&#x5F0F;&#x539F;&#x7406;</h5>
<p>1.&#x89C2;&#x5BDF;&#x8005;observer&#xFF1A;&#x9996;&#x5148;&#x901A;&#x8FC7;&#x89C2;&#x5BDF;&#x8005;&#x5BF9;data&#x4E2D;&#x7684;&#x5C5E;&#x6027;&#x4F7F;&#x7528;object.defineproperty&#x52AB;&#x6301;&#x6570;&#x636E;&#x7684;getter&#x548C;setter&#xFF0C;&#x901A;&#x77E5;&#x8BA2;&#x9605;&#x8005;&#xFF0C;&#x89E6;&#x53D1;&#x4ED6;&#x7684;update&#x65B9;&#x6CD5;&#xFF0C;&#x5BF9;&#x89C6;&#x56FE;&#x8FDB;&#x884C;&#x66F4;&#x65B0;</p>
<p>2.Compile&#xFF1A;&#x7528;&#x6765;&#x89E3;&#x6790;&#x6A21;&#x677F;&#x6307;&#x4EE4;&#xFF0C;&#x5E76;&#x66FF;&#x6362;&#x6A21;&#x677F;&#x6570;&#x636E;&#xFF0C;&#x521D;&#x59CB;&#x5316;&#x89C6;&#x56FE;&#xFF0C;&#x521D;&#x59CB;&#x5316;&#x76F8;&#x5E94;&#x7684;&#x8BA2;&#x9605;&#x5668;</p>
<p>3.&#x8BA2;&#x9605;&#x8005;Watcher&#xFF1A;&#x8BA2;&#x9605;&#x8005;&#x63A5;&#x5230;&#x901A;&#x77E5;&#x540E;&#xFF0C;&#x8C03;&#x7528;update&#x65B9;&#x6CD5;&#x66F4;&#x65B0;&#x5BF9;&#x5E94;&#x7684;&#x89C6;&#x56FE;</p>
<p>4.&#x8BA2;&#x9605;&#x5668;Dep&#xFF1A;&#x8BA2;&#x9605;&#x8005;&#x53EF;&#x80FD;&#x6709;&#x591A;&#x4E2A;&#xFF0C;&#x56E0;&#x6B64;&#x9700;&#x8981;&#x8BA2;&#x9605;&#x5668;Dep&#x6765;&#x4E13;&#x95E8;&#x63A5;&#x6536;&#x8FD9;&#x4E9B;&#x8BA2;&#x9605;&#x8005;&#xFF0C;&#x5E76;&#x7EDF;&#x4E00;&#x7BA1;&#x7406;</p>
<p>&#x4F46;&#x5728;vue3&#x4E2D;&#x629B;&#x5F03;&#x4E86;object.defineproperty&#x65B9;&#x6CD5;&#xFF0C;&#x56E0;&#x4E3A;</p>
<p>1.Object.defineproperty&#x65E0;&#x6CD5;&#x76D1;&#x6D4B;<strong>&#x5BF9;&#x8C61;&#x5C5E;&#x6027;&#x7684;&#x6DFB;&#x52A0;&#x548C;&#x5220;&#x9664;</strong>&#x3001;<strong>&#x6570;&#x7EC4;&#x7D22;&#x5F15;&#x548C;&#x957F;&#x5EA6;&#x7684;&#x53D8;&#x66F4;</strong>&#xFF0C;&#x56E0;&#x6B64;vue&#x91CD;&#x5199;&#x4E86;&#x6570;&#x7EC4;&#x7684;push/pop/shift/unshift/splice/sort/reverse&#x65B9;&#x6CD5;</p>
<p>2.Object.defineProperty&#x53EA;&#x80FD;&#x52AB;&#x6301;&#x5BF9;&#x8C61;&#x7684;&#x5C5E;&#x6027;,&#x56E0;&#x6B64;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x5BF9;&#x6BCF;&#x4E2A;&#x5BF9;&#x8C61;&#x7684;&#x6BCF;&#x4E2A;&#x5C5E;&#x6027;&#x8FDB;&#x884C;&#x904D;&#x5386;&#xFF0C;&#x8FD9;&#x6837;&#x5F88;&#x6D88;&#x8017;&#x6027;&#x80FD;</p>
<p>vue3&#x4E2D;&#x5B9E;&#x73B0;&#x6570;&#x636E;&#x53CC;&#x5411;&#x7ED1;&#x5B9A;&#x7684;&#x539F;&#x7406;&#x662F;&#x6570;&#x636E;&#x4EE3;&#x7406;&#xFF0C;&#x4F7F;&#x7528;proxy&#x5B9E;&#x73B0;&#x3002;Proxy &#x53EF;&#x4EE5;&#x7406;&#x89E3;&#x6210;&#xFF0C;&#x5728;&#x76EE;&#x6807;&#x5BF9;&#x8C61;&#x4E4B;&#x524D;&#x67B6;&#x8BBE;&#x4E00;&#x5C42;&#x201C;&#x62E6;&#x622A;&#x201D;&#xFF0C;&#x5916;&#x754C;&#x5BF9;&#x8BE5;&#x5BF9;&#x8C61;&#x7684;&#x8BBF;&#x95EE;&#xFF0C;&#x90FD;&#x5FC5;&#x987B;&#x5148;&#x901A;&#x8FC7;&#x8FD9;&#x5C42;&#x62E6;&#x622A;&#xFF0C;&#x56E0;&#x6B64;&#x63D0;&#x4F9B;&#x4E86;&#x4E00;&#x79CD;&#x673A;&#x5236;&#xFF0C;&#x53EF;&#x4EE5;&#x5BF9;&#x5916;&#x754C;&#x7684;&#x8BBF;&#x95EE;&#x8FDB;&#x884C;&#x8FC7;&#x6EE4;&#x548C;&#x6539;&#x5199;&#x3002;</p>
<h5 id="55-&#x2605;&#x2605;&#x2605;&#x2605;-vue-proxy&#x7684;&#x539F;&#x7406;"><a name="55-&#x2605;&#x2605;&#x2605;&#x2605;-vue-proxy&#x7684;&#x539F;&#x7406;" class="anchor-navigation-ex-anchor" href="#55-&#x2605;&#x2605;&#x2605;&#x2605;-vue-proxy&#x7684;&#x539F;&#x7406;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="55-&#x2605;&#x2605;&#x2605;&#x2605;-vue-proxy&#x7684;&#x539F;&#x7406;" class="plugin-anchor" href="#55-&#x2605;&#x2605;&#x2605;&#x2605;-vue-proxy&#x7684;&#x539F;&#x7406;"><i class="fa fa-link" aria-hidden="true"></i></a>55. &#x2605;&#x2605;&#x2605;&#x2605; Vue proxy&#x7684;&#x539F;&#x7406;</h5>
<p> &#x4E3B;&#x8981;&#x901A;&#x8FC7;Proxy&#x5BF9;&#x5BF9;&#x8C61;&#x8FDB;&#x884C;&#x7ED1;&#x5B9A;&#x76D1;&#x542C;&#x5904;&#x7406;&#xFF0C;&#x901A;&#x8FC7;new Map&#x5BF9;&#x5BF9;&#x8C61;&#x7684;&#x5C5E;&#x6027;&#x64CD;&#x4F5C;&#x8FDB;&#x884C;&#x5904;&#x7406;&#xFF0C;&#x5C06;&#x8981;&#x6267;&#x884C;&#x7684;&#x51FD;&#x6570;&#x5339;&#x914D;&#x5230;&#x5B58;&#x5230;&#x5BF9;&#x5E94;&#x7684;prop&#x4E0A;&#x9762;&#xFF0C;&#x901A;&#x8FC7;&#x6BCF;&#x6B21;&#x7684;&#x8BBF;&#x95EE;&#x89E6;&#x53D1;get&#x65B9;&#x6CD5;&#xFF0C;&#x8FDB;&#x884C;&#x5B58;&#x65B9;&#x6CD5;&#x7684;&#x64CD;&#x4F5C;&#xFF0C;&#x901A;&#x8FC7;&#x4FEE;&#x6539;&#x89E6;&#x53D1;set&#x7684;&#x65B9;&#x6CD5;&#xFF0C;&#x6B64;&#x65F6;&#x6267;&#x884C;&#x56DE;&#x8C03;&#x76D1;&#x542C;&#x7684;&#x51FD;&#x6570;&#xFF0C;&#x8FD9;&#x6837;&#x8FBE;&#x5230;&#x4FEE;&#x6539;&#x6570;&#x636E;&#x548C;&#x89C6;&#x56FE;&#x7684; </p>
<p><a href="https://www.yuque.com/zhongyangweizao/wheel/off7wo" target="_blank">&#x53C2;&#x8003;</a></p>
<h5 id="56-&#x2605;&#x2605;&#x2605;-vue-forceupdate&#x7684;&#x539F;&#x7406;"><a name="56-&#x2605;&#x2605;&#x2605;-vue-forceupdate&#x7684;&#x539F;&#x7406;" class="anchor-navigation-ex-anchor" href="#56-&#x2605;&#x2605;&#x2605;-vue-forceupdate&#x7684;&#x539F;&#x7406;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="56-&#x2605;&#x2605;&#x2605;-vue-forceupdate&#x7684;&#x539F;&#x7406;" class="plugin-anchor" href="#56-&#x2605;&#x2605;&#x2605;-vue-forceupdate&#x7684;&#x539F;&#x7406;"><i class="fa fa-link" aria-hidden="true"></i></a>56. &#x2605;&#x2605;&#x2605; Vue $forceUpdate&#x7684;&#x539F;&#x7406;</h5>
<p><strong>1&#x3001;&#x4F5C;&#x7528;&#xFF1A;</strong></p>
<p>&#x8FEB;&#x4F7F; <code>Vue</code> &#x5B9E;&#x4F8B;&#x91CD;&#x65B0;&#x6E32;&#x67D3;&#x3002;&#x6CE8;&#x610F;&#x5B83;&#x4EC5;&#x4EC5;&#x5F71;&#x54CD;&#x5B9E;&#x4F8B;&#x672C;&#x8EAB;&#x548C;&#x63D2;&#x5165;&#x63D2;&#x69FD;&#x5185;&#x5BB9;&#x7684;&#x5B50;&#x7EC4;&#x4EF6;&#xFF0C;&#x800C;&#x4E0D;&#x662F;&#x6240;&#x6709;&#x5B50;&#x7EC4;&#x4EF6;&#x3002;</p>
<p><strong>2&#x3001;&#x5185;&#x90E8;&#x539F;&#x7406;&#xFF1A;</strong></p>
<pre><code class="lang-js">Vue.prototype.$forceUpdate = <span class="hljs-function"><span class="hljs-keyword">function</span> (<span class="hljs-params"></span>) </span>{
    <span class="hljs-keyword">const</span> vm: Component = <span class="hljs-keyword">this</span>
    <span class="hljs-keyword">if</span> (vm._watcher) {
        vm._watcher.update()
    }
}
</code></pre>
<p>&#x5B9E;&#x4F8B;&#x9700;&#x8981;&#x91CD;&#x65B0;&#x6E32;&#x67D3;&#x662F;&#x5728;&#x4F9D;&#x8D56;&#x53D1;&#x751F;&#x53D8;&#x5316;&#x7684;&#x65F6;&#x5019;&#x4F1A;&#x901A;&#x77E5;watcher&#xFF0C;&#x7136;&#x540E;&#x901A;&#x77E5;watcher&#x6765;&#x8C03;&#x7528;update&#x65B9;&#x6CD5;&#xFF0C;&#x5C31;&#x662F;&#x8FD9;&#x4E48;&#x7B80;&#x5355;&#x3002;</p>
<h5 id="57-&#x2605;&#x2605;&#x2605;-v-for-key"><a name="57-&#x2605;&#x2605;&#x2605;-v-for-key" class="anchor-navigation-ex-anchor" href="#57-&#x2605;&#x2605;&#x2605;-v-for-key"><i class="fa fa-link" aria-hidden="true"></i></a><a name="57-&#x2605;&#x2605;&#x2605;-v-for-key" class="plugin-anchor" href="#57-&#x2605;&#x2605;&#x2605;-v-for-key"><i class="fa fa-link" aria-hidden="true"></i></a>57. &#x2605;&#x2605;&#x2605; v-for key</h5>
<ul>
<li>key&#x662F;&#x4E3A;Vue&#x4E2D;&#x7684;vnode&#x6807;&#x8BB0;&#x7684;&#x552F;&#x4E00;id,&#x901A;&#x8FC7;&#x8FD9;&#x4E2A;key,&#x6211;&#x4EEC;&#x7684;diff&#x64CD;&#x4F5C;&#x53EF;&#x4EE5;&#x66F4;&#x51C6;&#x786E;&#x3001;&#x66F4;&#x5FEB;&#x901F;</li>
<li>diff&#x7B97;&#x6CD5;&#x7684;&#x8FC7;&#x7A0B;&#x4E2D;,&#x5148;&#x4F1A;&#x8FDB;&#x884C;&#x65B0;&#x65E7;&#x8282;&#x70B9;&#x7684;&#x9996;&#x5C3E;&#x4EA4;&#x53C9;&#x5BF9;&#x6BD4;,&#x5F53;&#x65E0;&#x6CD5;&#x5339;&#x914D;&#x7684;&#x65F6;&#x5019;&#x4F1A;&#x7528;&#x65B0;&#x8282;&#x70B9;&#x7684;key&#x4E0E;&#x65E7;&#x8282;&#x70B9;&#x8FDB;&#x884C;&#x6BD4;&#x5BF9;,&#x7136;&#x540E;&#x8D85;&#x51FA;&#x5DEE;&#x5F02;.</li>
</ul>
<blockquote>
<p>diff&#x7A0B;&#x53EF;&#x4EE5;&#x6982;&#x62EC;&#x4E3A;&#xFF1A;oldCh&#x548C;newCh&#x5404;&#x6709;&#x4E24;&#x4E2A;&#x5934;&#x5C3E;&#x7684;&#x53D8;&#x91CF;StartIdx&#x548C;EndIdx&#xFF0C;&#x5B83;&#x4EEC;&#x7684;2&#x4E2A;&#x53D8;&#x91CF;&#x76F8;&#x4E92;&#x6BD4;&#x8F83;&#xFF0C;&#x4E00;&#x5171;&#x6709;4&#x79CD;&#x6BD4;&#x8F83;&#x65B9;&#x5F0F;&#x3002;&#x5982;&#x679C;4&#x79CD;&#x6BD4;&#x8F83;&#x90FD;&#x6CA1;&#x5339;&#x914D;&#xFF0C;&#x5982;&#x679C;&#x8BBE;&#x7F6E;&#x4E86;key&#xFF0C;&#x5C31;&#x4F1A;&#x7528;key&#x8FDB;&#x884C;&#x6BD4;&#x8F83;&#xFF0C;&#x5728;&#x6BD4;&#x8F83;&#x7684;&#x8FC7;&#x7A0B;&#x4E2D;&#xFF0C;&#x53D8;&#x91CF;&#x4F1A;&#x5F80;&#x4E2D;&#x95F4;&#x9760;&#xFF0C;&#x4E00;&#x65E6;StartIdx&gt;EndIdx&#x8868;&#x660E;oldCh&#x548C;newCh&#x81F3;&#x5C11;&#x6709;&#x4E00;&#x4E2A;&#x5DF2;&#x7ECF;&#x904D;&#x5386;&#x5B8C;&#x4E86;&#xFF0C;&#x5C31;&#x4F1A;&#x7ED3;&#x675F;&#x6BD4;&#x8F83;,&#x8FD9;&#x56DB;&#x79CD;&#x6BD4;&#x8F83;&#x65B9;&#x5F0F;&#x5C31;&#x662F;&#x9996;&#x3001;&#x5C3E;&#x3001;&#x65E7;&#x5C3E;&#x65B0;&#x5934;&#x3001;&#x65E7;&#x5934;&#x65B0;&#x5C3E;.</p>
<p>&#x51C6;&#x786E;: &#x5982;&#x679C;&#x4E0D;&#x52A0;key,&#x90A3;&#x4E48;vue&#x4F1A;&#x9009;&#x62E9;&#x590D;&#x7528;&#x8282;&#x70B9;(Vue&#x7684;&#x5C31;&#x5730;&#x66F4;&#x65B0;&#x7B56;&#x7565;),&#x5BFC;&#x81F4;&#x4E4B;&#x524D;&#x8282;&#x70B9;&#x7684;&#x72B6;&#x6001;&#x88AB;&#x4FDD;&#x7559;&#x4E0B;&#x6765;,&#x4F1A;&#x4EA7;&#x751F;&#x4E00;&#x7CFB;&#x5217;&#x7684;bug. &#x5FEB;&#x901F;: key&#x7684;&#x552F;&#x4E00;&#x6027;&#x53EF;&#x4EE5;&#x88AB;Map&#x6570;&#x636E;&#x7ED3;&#x6784;&#x5145;&#x5206;&#x5229;&#x7528;,&#x76F8;&#x6BD4;&#x4E8E;&#x904D;&#x5386;&#x67E5;&#x627E;&#x7684;&#x65F6;&#x95F4;&#x590D;&#x6742;&#x5EA6;<code>O(n)</code>,<code>Map</code>&#x7684;&#x65F6;&#x95F4;&#x590D;&#x6742;&#x5EA6;&#x4EC5;&#x4EC5;&#x4E3A;<code>O(1)</code></p>
</blockquote>
<p><a href="https://www.jianshu.com/p/4bd5e745ce95" target="_blank">&#x5EFA;&#x8BAE;&#x4F7F;&#x7528;id&#xFF0C;&#x4E0D;&#x5EFA;&#x8BAE;&#x4F7F;&#x7528;&#x7D22;&#x5F15;</a></p>
<h5 id="58-&#x2605;&#x2605;&#x2605;&#x2605;-defineproperty&#x5728;&#x6570;&#x636E;&#x52AB;&#x6301;&#x540E;&#x662F;&#x5982;&#x4F55;&#x901A;&#x77E5;&#x6570;&#x636E;&#x7684;&#x66F4;&#x65B0;&#x548C;&#x89C6;&#x56FE;&#x7684;&#x66F4;&#x65B0;&#x7684;"><a name="58-&#x2605;&#x2605;&#x2605;&#x2605;-defineproperty&#x5728;&#x6570;&#x636E;&#x52AB;&#x6301;&#x540E;&#x662F;&#x5982;&#x4F55;&#x901A;&#x77E5;&#x6570;&#x636E;&#x7684;&#x66F4;&#x65B0;&#x548C;&#x89C6;&#x56FE;&#x7684;&#x66F4;&#x65B0;&#x7684;" class="anchor-navigation-ex-anchor" href="#58-&#x2605;&#x2605;&#x2605;&#x2605;-defineproperty&#x5728;&#x6570;&#x636E;&#x52AB;&#x6301;&#x540E;&#x662F;&#x5982;&#x4F55;&#x901A;&#x77E5;&#x6570;&#x636E;&#x7684;&#x66F4;&#x65B0;&#x548C;&#x89C6;&#x56FE;&#x7684;&#x66F4;&#x65B0;&#x7684;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="58-&#x2605;&#x2605;&#x2605;&#x2605;-defineproperty&#x5728;&#x6570;&#x636E;&#x52AB;&#x6301;&#x540E;&#x662F;&#x5982;&#x4F55;&#x901A;&#x77E5;&#x6570;&#x636E;&#x7684;&#x66F4;&#x65B0;&#x548C;&#x89C6;&#x56FE;&#x7684;&#x66F4;&#x65B0;&#x7684;" class="plugin-anchor" href="#58-&#x2605;&#x2605;&#x2605;&#x2605;-defineproperty&#x5728;&#x6570;&#x636E;&#x52AB;&#x6301;&#x540E;&#x662F;&#x5982;&#x4F55;&#x901A;&#x77E5;&#x6570;&#x636E;&#x7684;&#x66F4;&#x65B0;&#x548C;&#x89C6;&#x56FE;&#x7684;&#x66F4;&#x65B0;&#x7684;"><i class="fa fa-link" aria-hidden="true"></i></a>58. &#x2605;&#x2605;&#x2605;&#x2605; defineProperty&#x5728;&#x6570;&#x636E;&#x52AB;&#x6301;&#x540E;&#x662F;&#x5982;&#x4F55;&#x901A;&#x77E5;&#x6570;&#x636E;&#x7684;&#x66F4;&#x65B0;&#x548C;&#x89C6;&#x56FE;&#x7684;&#x66F4;&#x65B0;&#x7684;</h5>
<p>vue&#x7684;&#x53CC;&#x5411;&#x7ED1;&#x5B9A;&#x662F;&#x7531;&#x6570;&#x636E;&#x52AB;&#x6301;&#x7ED3;&#x5408;&#x53D1;&#x5E03;&#x8005;&#xFF0D;&#x8BA2;&#x9605;&#x8005;&#x6A21;&#x5F0F;&#x5B9E;&#x73B0;&#x7684;&#xFF0C;&#x90A3;&#x4E48;&#x4EC0;&#x4E48;&#x662F;&#x6570;&#x636E;&#x52AB;&#x6301;&#xFF1F;vue&#x662F;&#x5982;&#x4F55;&#x8FDB;&#x884C;&#x6570;&#x636E;&#x52AB;&#x6301;&#x7684;&#xFF1F;&#x8BF4;&#x767D;&#x4E86;&#x5C31;&#x662F;&#x901A;&#x8FC7;Object.defineProperty()&#x6765;&#x52AB;&#x6301;&#x5BF9;&#x8C61;&#x5C5E;&#x6027;&#x7684;setter&#x548C;getter&#x64CD;&#x4F5C;&#xFF0C;&#x5728;&#x6570;&#x636E;&#x53D8;&#x52A8;&#x65F6;&#x505A;&#x4F60;&#x60F3;&#x8981;&#x505A;&#x7684;&#x4E8B;&#x60C5;</p>
<p>&#x6211;&#x4EEC;&#x5DF2;&#x7ECF;&#x77E5;&#x9053;&#x5B9E;&#x73B0;&#x6570;&#x636E;&#x7684;&#x53CC;&#x5411;&#x7ED1;&#x5B9A;&#xFF0C;&#x9996;&#x5148;&#x8981;&#x5BF9;&#x6570;&#x636E;&#x8FDB;&#x884C;&#x52AB;&#x6301;&#x76D1;&#x542C;&#xFF0C;&#x6240;&#x4EE5;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x8BBE;&#x7F6E;&#x4E00;&#x4E2A;&#x76D1;&#x542C;&#x5668;Observer&#xFF0C;&#x7528;&#x6765;&#x76D1;&#x542C;&#x6240;&#x6709;&#x5C5E;&#x6027;&#x3002;&#x5982;&#x679C;&#x5C5E;&#x6027;&#x53D1;&#x751F;&#x53D8;&#x5316;&#x4E86;&#xFF0C;&#x5C31;&#x9700;&#x8981;&#x544A;&#x8BC9;&#x8BA2;&#x9605;&#x8005;Watcher&#x770B;&#x662F;&#x5426;&#x9700;&#x8981;&#x66F4;&#x65B0;&#x3002;&#x56E0;&#x4E3A;&#x8BA2;&#x9605;&#x8005;&#x662F;&#x6709;&#x5F88;&#x591A;&#x4E2A;&#xFF0C;&#x6240;&#x4EE5;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x6709;&#x4E00;&#x4E2A;&#x6D88;&#x606F;&#x8BA2;&#x9605;&#x5668;Dep&#x6765;&#x4E13;&#x95E8;&#x6536;&#x96C6;&#x8FD9;&#x4E9B;&#x8BA2;&#x9605;&#x8005;&#xFF0C;&#x7136;&#x540E;&#x5728;&#x76D1;&#x542C;&#x5668;Observer&#x548C;&#x8BA2;&#x9605;&#x8005;Watcher&#x4E4B;&#x95F4;&#x8FDB;&#x884C;&#x7EDF;&#x4E00;&#x7BA1;&#x7406;&#x7684;&#x3002;&#x63A5;&#x7740;&#xFF0C;&#x6211;&#x4EEC;&#x8FD8;&#x9700;&#x8981;&#x6709;&#x4E00;&#x4E2A;&#x6307;&#x4EE4;&#x89E3;&#x6790;&#x5668;Compile&#xFF0C;&#x5BF9;&#x6BCF;&#x4E2A;&#x8282;&#x70B9;&#x5143;&#x7D20;&#x8FDB;&#x884C;&#x626B;&#x63CF;&#x548C;&#x89E3;&#x6790;&#xFF0C;&#x5C06;&#x76F8;&#x5173;&#x6307;&#x4EE4;&#xFF08;&#x5982;v-model&#xFF0C;v-on&#xFF09;&#x5BF9;&#x5E94;&#x521D;&#x59CB;&#x5316;&#x6210;&#x4E00;&#x4E2A;&#x8BA2;&#x9605;&#x8005;Watcher&#xFF0C;&#x5E76;&#x66FF;&#x6362;&#x6A21;&#x677F;&#x6570;&#x636E;&#x6216;&#x8005;&#x7ED1;&#x5B9A;&#x76F8;&#x5E94;&#x7684;&#x51FD;&#x6570;&#xFF0C;&#x6B64;&#x65F6;&#x5F53;&#x8BA2;&#x9605;&#x8005;Watcher&#x63A5;&#x6536;&#x5230;&#x76F8;&#x5E94;&#x5C5E;&#x6027;&#x7684;&#x53D8;&#x5316;&#xFF0C;&#x5C31;&#x4F1A;&#x6267;&#x884C;&#x5BF9;&#x5E94;&#x7684;&#x66F4;&#x65B0;&#x51FD;&#x6570;&#xFF0C;&#x4ECE;&#x800C;&#x66F4;&#x65B0;&#x89C6;&#x56FE;&#x3002;&#x56E0;&#x6B64;&#x63A5;&#x4E0B;&#x53BB;&#x6211;&#x4EEC;&#x6267;&#x884C;&#x4EE5;&#x4E0B;3&#x4E2A;&#x6B65;&#x9AA4;&#xFF0C;&#x5B9E;&#x73B0;&#x6570;&#x636E;&#x7684;&#x53CC;&#x5411;&#x7ED1;&#x5B9A;&#xFF1A;</p>
<p>1.&#x5B9E;&#x73B0;&#x4E00;&#x4E2A;&#x76D1;&#x542C;&#x5668;Observer&#xFF0C;&#x7528;&#x6765;&#x52AB;&#x6301;&#x5E76;&#x76D1;&#x542C;&#x6240;&#x6709;&#x5C5E;&#x6027;&#xFF0C;&#x5982;&#x679C;&#x6709;&#x53D8;&#x52A8;&#x7684;&#xFF0C;&#x5C31;&#x901A;&#x77E5;&#x8BA2;&#x9605;&#x8005;&#x3002;</p>
<p>2.&#x5B9E;&#x73B0;&#x4E00;&#x4E2A;&#x8BA2;&#x9605;&#x8005;Watcher&#xFF0C;&#x6BCF;&#x4E00;&#x4E2A;Watcher&#x90FD;&#x7ED1;&#x5B9A;&#x4E00;&#x4E2A;&#x66F4;&#x65B0;&#x51FD;&#x6570;&#xFF0C;watcher&#x53EF;&#x4EE5;&#x6536;&#x5230;&#x5C5E;&#x6027;&#x7684;&#x53D8;&#x5316;&#x901A;&#x77E5;&#x5E76;&#x6267;&#x884C;&#x76F8;&#x5E94;&#x7684;&#x51FD;&#x6570;&#xFF0C;&#x4ECE;&#x800C;&#x66F4;&#x65B0;&#x89C6;&#x56FE;&#x3002;</p>
<p>3.&#x5B9E;&#x73B0;&#x4E00;&#x4E2A;&#x89E3;&#x6790;&#x5668;Compile&#xFF0C;&#x53EF;&#x4EE5;&#x626B;&#x63CF;&#x548C;&#x89E3;&#x6790;&#x6BCF;&#x4E2A;&#x8282;&#x70B9;&#x7684;&#x76F8;&#x5173;&#x6307;&#x4EE4;&#xFF08;v-model&#xFF0C;v-on&#x7B49;&#x6307;&#x4EE4;&#xFF09;&#xFF0C;&#x5982;&#x679C;&#x8282;&#x70B9;&#x5B58;&#x5728;v-model&#xFF0C;v-on&#x7B49;&#x6307;&#x4EE4;&#xFF0C;&#x5219;&#x89E3;&#x6790;&#x5668;Compile&#x521D;&#x59CB;&#x5316;&#x8FD9;&#x7C7B;&#x8282;&#x70B9;&#x7684;&#x6A21;&#x677F;&#x6570;&#x636E;&#xFF0C;&#x4F7F;&#x4E4B;&#x53EF;&#x4EE5;&#x663E;&#x793A;&#x5728;&#x89C6;&#x56FE;&#x4E0A;&#xFF0C;&#x7136;&#x540E;&#x521D;&#x59CB;&#x5316;&#x76F8;&#x5E94;&#x7684;&#x8BA2;&#x9605;&#x8005;&#xFF08;Watcher&#xFF09;&#x3002;</p>
<h5 id="59-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x662F;&#x600E;&#x4E48;&#x505A;&#x865A;&#x62DF;dom&#x7684;diff&#x7684;"><a name="59-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x662F;&#x600E;&#x4E48;&#x505A;&#x865A;&#x62DF;dom&#x7684;diff&#x7684;" class="anchor-navigation-ex-anchor" href="#59-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x662F;&#x600E;&#x4E48;&#x505A;&#x865A;&#x62DF;dom&#x7684;diff&#x7684;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="59-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x662F;&#x600E;&#x4E48;&#x505A;&#x865A;&#x62DF;dom&#x7684;diff&#x7684;" class="plugin-anchor" href="#59-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x662F;&#x600E;&#x4E48;&#x505A;&#x865A;&#x62DF;dom&#x7684;diff&#x7684;"><i class="fa fa-link" aria-hidden="true"></i></a>59. &#x2605;&#x2605;&#x2605;&#x2605; Vue&#x662F;&#x600E;&#x4E48;&#x505A;&#x865A;&#x62DF;DOM&#x7684;diff&#x7684;</h5>
<p><a href="https://segmentfault.com/a/1190000020663531?utm_source=tag-newest" target="_blank">&#x5B9E;&#x73B0;&#x865A;&#x62DF;DOM&#x7684;&#x8FC7;&#x7A0B;</a></p>
<h5 id="60-&#x2605;&#x2605;&#x2605;&#x2605;-vuex&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x8DE8;&#x7EC4;&#x4EF7;&#x7684;&#x6570;&#x636E;&#x76D1;&#x542C;"><a name="60-&#x2605;&#x2605;&#x2605;&#x2605;-vuex&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x8DE8;&#x7EC4;&#x4EF7;&#x7684;&#x6570;&#x636E;&#x76D1;&#x542C;" class="anchor-navigation-ex-anchor" href="#60-&#x2605;&#x2605;&#x2605;&#x2605;-vuex&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x8DE8;&#x7EC4;&#x4EF7;&#x7684;&#x6570;&#x636E;&#x76D1;&#x542C;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="60-&#x2605;&#x2605;&#x2605;&#x2605;-vuex&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x8DE8;&#x7EC4;&#x4EF7;&#x7684;&#x6570;&#x636E;&#x76D1;&#x542C;" class="plugin-anchor" href="#60-&#x2605;&#x2605;&#x2605;&#x2605;-vuex&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x8DE8;&#x7EC4;&#x4EF7;&#x7684;&#x6570;&#x636E;&#x76D1;&#x542C;"><i class="fa fa-link" aria-hidden="true"></i></a>60. &#x2605;&#x2605;&#x2605;&#x2605; Vuex&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x8DE8;&#x7EC4;&#x4EF7;&#x7684;&#x6570;&#x636E;&#x76D1;&#x542C;</h5>
<h5 id="61-&#x2605;&#x2605;&#x2605;&#x2605;-&#x4E2D;&#x95F4;&#x4EF6;&#x673A;&#x5236;&#x662F;&#x600E;&#x4E48;&#x751F;&#x6548;&#x7684;"><a name="61-&#x2605;&#x2605;&#x2605;&#x2605;-&#x4E2D;&#x95F4;&#x4EF6;&#x673A;&#x5236;&#x662F;&#x600E;&#x4E48;&#x751F;&#x6548;&#x7684;" class="anchor-navigation-ex-anchor" href="#61-&#x2605;&#x2605;&#x2605;&#x2605;-&#x4E2D;&#x95F4;&#x4EF6;&#x673A;&#x5236;&#x662F;&#x600E;&#x4E48;&#x751F;&#x6548;&#x7684;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="61-&#x2605;&#x2605;&#x2605;&#x2605;-&#x4E2D;&#x95F4;&#x4EF6;&#x673A;&#x5236;&#x662F;&#x600E;&#x4E48;&#x751F;&#x6548;&#x7684;" class="plugin-anchor" href="#61-&#x2605;&#x2605;&#x2605;&#x2605;-&#x4E2D;&#x95F4;&#x4EF6;&#x673A;&#x5236;&#x662F;&#x600E;&#x4E48;&#x751F;&#x6548;&#x7684;"><i class="fa fa-link" aria-hidden="true"></i></a>61. &#x2605;&#x2605;&#x2605;&#x2605; &#x4E2D;&#x95F4;&#x4EF6;&#x673A;&#x5236;&#x662F;&#x600E;&#x4E48;&#x751F;&#x6548;&#x7684;</h5>
<h5 id="62-&#x2605;&#x2605;&#x2605;&#x2605;-axios&#x8C01;&#x5C01;&#x88C5;&#x7684;&#xFF0C;&#x600E;&#x4E48;&#x5C01;&#x88C5;&#x7684;"><a name="62-&#x2605;&#x2605;&#x2605;&#x2605;-axios&#x8C01;&#x5C01;&#x88C5;&#x7684;&#xFF0C;&#x600E;&#x4E48;&#x5C01;&#x88C5;&#x7684;" class="anchor-navigation-ex-anchor" href="#62-&#x2605;&#x2605;&#x2605;&#x2605;-axios&#x8C01;&#x5C01;&#x88C5;&#x7684;&#xFF0C;&#x600E;&#x4E48;&#x5C01;&#x88C5;&#x7684;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="62-&#x2605;&#x2605;&#x2605;&#x2605;-axios&#x8C01;&#x5C01;&#x88C5;&#x7684;&#xFF0C;&#x600E;&#x4E48;&#x5C01;&#x88C5;&#x7684;" class="plugin-anchor" href="#62-&#x2605;&#x2605;&#x2605;&#x2605;-axios&#x8C01;&#x5C01;&#x88C5;&#x7684;&#xFF0C;&#x600E;&#x4E48;&#x5C01;&#x88C5;&#x7684;"><i class="fa fa-link" aria-hidden="true"></i></a>62. &#x2605;&#x2605;&#x2605;&#x2605; axios&#x8C01;&#x5C01;&#x88C5;&#x7684;&#xFF0C;&#x600E;&#x4E48;&#x5C01;&#x88C5;&#x7684;</h5>
<pre><code class="lang-js"><span class="hljs-comment">// &#x4F7F;&#x7528;axios&#x7528;&#x4E8E;&#x5BF9;&#x6570;&#x636E;&#x7684;&#x8BF7;&#x6C42;</span>
<span class="hljs-keyword">import</span> axios <span class="hljs-keyword">from</span> <span class="hljs-string">&apos;axios&apos;</span>
<span class="hljs-comment">// &#x521B;&#x5EFA;axios&#x5B9E;&#x4F8B;</span>
<span class="hljs-keyword">const</span> instance = axios.create({
  baseURL: baseURL + version,
  timeout: <span class="hljs-number">5000</span>
})

<span class="hljs-comment">// &#x521B;&#x5EFA;&#x8BF7;&#x6C42;&#x7684;&#x62E6;&#x622A;&#x5668;</span>
instance.interceptors.request.use(config =&gt; {
  config.headers[<span class="hljs-string">&apos;Authorization&apos;</span>] = localStorage.getItem(<span class="hljs-string">&apos;token&apos;</span>)
  <span class="hljs-keyword">return</span> config
}, error =&gt; {
  <span class="hljs-keyword">return</span> <span class="hljs-built_in">Promise</span>.reject(error)
})

<span class="hljs-comment">// &#x521B;&#x5EFA;&#x54CD;&#x5E94;&#x7684;&#x62E6;&#x622A;&#x5668;</span>
instance.interceptors.response.use(response =&gt; {
  <span class="hljs-keyword">let</span> res = <span class="hljs-literal">null</span>

  <span class="hljs-comment">// &#x5BF9;&#x76F8;&#x5E94;&#x7684;&#x6570;&#x636E;&#x8FDB;&#x884C;&#x8FC7;&#x6EE4;</span>
  <span class="hljs-keyword">if</span> (response.status === <span class="hljs-number">200</span>) {
    <span class="hljs-keyword">if</span> (response.data &amp;&amp; response.data.err === <span class="hljs-number">0</span>) {
      res = response.data.data
    } <span class="hljs-keyword">else</span> <span class="hljs-keyword">if</span> (response.data.err === <span class="hljs-number">-1</span>) {
      <span class="hljs-keyword">return</span> alert(<span class="hljs-string">&apos;token&#x65E0;&#x6548;&apos;</span>)
    }
  } <span class="hljs-keyword">else</span> {
    <span class="hljs-keyword">return</span> alert(<span class="hljs-string">&apos;&#x8BF7;&#x6C42;&#x5931;&#x8D25;&apos;</span>)
  }

  <span class="hljs-keyword">return</span> res
}, error =&gt; {
  <span class="hljs-keyword">return</span> <span class="hljs-built_in">Promise</span>.reject(error)
})

<span class="hljs-keyword">export</span> <span class="hljs-keyword">default</span> instance
</code></pre>
<h5 id="63-&#x2605;&#x2605;&#x2605;-&#x4E3A;&#x4EC0;&#x4E48;&#x8981;&#x8BBE;&#x7F6E;key&#x503C;&#xFF0C;&#x53EF;&#x4EE5;&#x7528;index&#x5417;&#xFF1F;&#x4E3A;&#x4EC0;&#x4E48;&#x4E0D;&#x80FD;&#xFF1F;"><a name="63-&#x2605;&#x2605;&#x2605;-&#x4E3A;&#x4EC0;&#x4E48;&#x8981;&#x8BBE;&#x7F6E;key&#x503C;&#xFF0C;&#x53EF;&#x4EE5;&#x7528;index&#x5417;&#xFF1F;&#x4E3A;&#x4EC0;&#x4E48;&#x4E0D;&#x80FD;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#63-&#x2605;&#x2605;&#x2605;-&#x4E3A;&#x4EC0;&#x4E48;&#x8981;&#x8BBE;&#x7F6E;key&#x503C;&#xFF0C;&#x53EF;&#x4EE5;&#x7528;index&#x5417;&#xFF1F;&#x4E3A;&#x4EC0;&#x4E48;&#x4E0D;&#x80FD;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="63-&#x2605;&#x2605;&#x2605;-&#x4E3A;&#x4EC0;&#x4E48;&#x8981;&#x8BBE;&#x7F6E;key&#x503C;&#xFF0C;&#x53EF;&#x4EE5;&#x7528;index&#x5417;&#xFF1F;&#x4E3A;&#x4EC0;&#x4E48;&#x4E0D;&#x80FD;&#xFF1F;" class="plugin-anchor" href="#63-&#x2605;&#x2605;&#x2605;-&#x4E3A;&#x4EC0;&#x4E48;&#x8981;&#x8BBE;&#x7F6E;key&#x503C;&#xFF0C;&#x53EF;&#x4EE5;&#x7528;index&#x5417;&#xFF1F;&#x4E3A;&#x4EC0;&#x4E48;&#x4E0D;&#x80FD;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>63. &#x2605;&#x2605;&#x2605; &#x4E3A;&#x4EC0;&#x4E48;&#x8981;&#x8BBE;&#x7F6E;key&#x503C;&#xFF0C;&#x53EF;&#x4EE5;&#x7528;index&#x5417;&#xFF1F;&#x4E3A;&#x4EC0;&#x4E48;&#x4E0D;&#x80FD;&#xFF1F;</h5>
<p>vue&#x4E2D;&#x5217;&#x8868;&#x5FAA;&#x73AF;&#x9700;&#x52A0;:key=&quot;&#x552F;&#x4E00;&#x6807;&#x8BC6;&quot; &#x552F;&#x4E00;&#x6807;&#x8BC6;&#x53EF;&#x4EE5;&#x662F;item&#x91CC;&#x9762;id index&#x7B49;&#xFF0C;&#x56E0;&#x4E3A;vue&#x7EC4;&#x4EF6;&#x9AD8;&#x5EA6;&#x590D;&#x7528;&#x589E;&#x52A0;Key&#x53EF;&#x4EE5;&#x6807;&#x8BC6;&#x7EC4;&#x4EF6;&#x7684;&#x552F;&#x4E00;&#x6027;&#xFF0C;&#x4E3A;&#x4E86;&#x66F4;&#x597D;&#x5730;&#x533A;&#x522B;&#x5404;&#x4E2A;&#x7EC4;&#x4EF6; key&#x7684;&#x4F5C;&#x7528;&#x4E3B;&#x8981;&#x662F;&#x4E3A;&#x4E86;&#x9AD8;&#x6548;&#x7684;&#x66F4;&#x65B0;&#x865A;&#x62DF;DOM</p>
<p><a href="https://blog.csdn.net/weixin_45629194/article/details/104969834" target="_blank">&#x8BE6;&#x60C5;&#x94FE;&#x63A5;</a></p>
<h5 id="64-&#x2605;&#x2605;&#x2605;-vue&#x7684;&#x865A;&#x62DF;dom"><a name="64-&#x2605;&#x2605;&#x2605;-vue&#x7684;&#x865A;&#x62DF;dom" class="anchor-navigation-ex-anchor" href="#64-&#x2605;&#x2605;&#x2605;-vue&#x7684;&#x865A;&#x62DF;dom"><i class="fa fa-link" aria-hidden="true"></i></a><a name="64-&#x2605;&#x2605;&#x2605;-vue&#x7684;&#x865A;&#x62DF;dom" class="plugin-anchor" href="#64-&#x2605;&#x2605;&#x2605;-vue&#x7684;&#x865A;&#x62DF;dom"><i class="fa fa-link" aria-hidden="true"></i></a>64. &#x2605;&#x2605;&#x2605; Vue&#x7684;&#x865A;&#x62DF;dom</h5>
<p><a href="https://blog.csdn.net/u010692018/article/details/78799335/" target="_blank">&#x53C2;&#x8003;</a></p>
<h5 id="65-&#x2605;&#x2605;&#x2605;-diff&#x590D;&#x6742;&#x5EA6;&#x539F;&#x7406;&#x53CA;&#x5177;&#x4F53;&#x8FC7;&#x7A0B;&#x753B;&#x56FE;"><a name="65-&#x2605;&#x2605;&#x2605;-diff&#x590D;&#x6742;&#x5EA6;&#x539F;&#x7406;&#x53CA;&#x5177;&#x4F53;&#x8FC7;&#x7A0B;&#x753B;&#x56FE;" class="anchor-navigation-ex-anchor" href="#65-&#x2605;&#x2605;&#x2605;-diff&#x590D;&#x6742;&#x5EA6;&#x539F;&#x7406;&#x53CA;&#x5177;&#x4F53;&#x8FC7;&#x7A0B;&#x753B;&#x56FE;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="65-&#x2605;&#x2605;&#x2605;-diff&#x590D;&#x6742;&#x5EA6;&#x539F;&#x7406;&#x53CA;&#x5177;&#x4F53;&#x8FC7;&#x7A0B;&#x753B;&#x56FE;" class="plugin-anchor" href="#65-&#x2605;&#x2605;&#x2605;-diff&#x590D;&#x6742;&#x5EA6;&#x539F;&#x7406;&#x53CA;&#x5177;&#x4F53;&#x8FC7;&#x7A0B;&#x753B;&#x56FE;"><i class="fa fa-link" aria-hidden="true"></i></a>65. &#x2605;&#x2605;&#x2605; diff&#x590D;&#x6742;&#x5EA6;&#x539F;&#x7406;&#x53CA;&#x5177;&#x4F53;&#x8FC7;&#x7A0B;&#x753B;&#x56FE;</h5>
<p>diff&#x7B97;&#x6CD5;&#x662F;&#x4E00;&#x79CD;&#x901A;&#x8FC7;&#x540C;&#x5C42;&#x7684;&#x6811;&#x8282;&#x70B9;&#x8FDB;&#x884C;&#x6BD4;&#x8F83;&#x7684;&#x9AD8;&#x6548;&#x7B97;&#x6CD5;&#xFF0C;&#x907F;&#x514D;&#x4E86;&#x5BF9;&#x6811;&#x8FDB;&#x884C;&#x9010;&#x5C42;&#x641C;&#x7D22;&#x904D;&#x5386;&#xFF0C;&#x6240;&#x4EE5;&#x65F6;&#x95F4;&#x590D;&#x6742;&#x5EA6;&#x53EA;&#x6709; O(n)&#x3002;</p>
<p>diff&#x7B97;&#x6CD5;&#x6709;&#x4E24;&#x4E2A;&#x6BD4;&#x8F83;&#x663E;&#x8457;&#x7684;&#x7279;&#x70B9;&#xFF1A;</p>
<p>1&#x3001;&#x6BD4;&#x8F83;&#x53EA;&#x4F1A;&#x5728;&#x540C;&#x5C42;&#x7EA7;&#x8FDB;&#x884C;, &#x4E0D;&#x4F1A;&#x8DE8;&#x5C42;&#x7EA7;&#x6BD4;&#x8F83;&#x3002;</p>
<p>2&#x3001;&#x5728;diff&#x6BD4;&#x8F83;&#x7684;&#x8FC7;&#x7A0B;&#x4E2D;&#xFF0C;&#x5FAA;&#x73AF;&#x4ECE;&#x4E24;&#x8FB9;&#x5411;&#x4E2D;&#x95F4;&#x6536;&#x62E2;&#x3002;</p>
<p>diff&#x6D41;&#x7A0B;&#xFF1A;
&#x9996;&#x5148;&#x5B9A;&#x4E49; oldStartIdx&#x3001;newStartIdx&#x3001;oldEndIdx &#x4EE5;&#x53CA; newEndIdx &#x5206;&#x522B;&#x662F;&#x65B0;&#x8001;&#x4E24;&#x4E2A; VNode &#x7684;&#x4E24;&#x8FB9;&#x7684;&#x7D22;&#x5F15;&#x3002;</p>
<p>&#x63A5;&#x4E0B;&#x6765;&#x662F;&#x4E00;&#x4E2A; while &#x5FAA;&#x73AF;&#xFF0C;&#x5728;&#x8FD9;&#x8FC7;&#x7A0B;&#x4E2D;&#xFF0C;oldStartIdx&#x3001;newStartIdx&#x3001;oldEndIdx &#x4EE5;&#x53CA; newEndIdx &#x4F1A;&#x9010;&#x6E10;&#x5411;&#x4E2D;&#x95F4;&#x9760;&#x62E2;&#x3002;while &#x5FAA;&#x73AF;&#x7684;&#x9000;&#x51FA;&#x6761;&#x4EF6;&#x662F;&#x76F4;&#x5230;&#x8001;&#x8282;&#x70B9;&#x6216;&#x8005;&#x65B0;&#x8282;&#x70B9;&#x7684;&#x5F00;&#x59CB;&#x4F4D;&#x7F6E;&#x5927;&#x4E8E;&#x7ED3;&#x675F;&#x4F4D;&#x7F6E;&#x3002;</p>
<p>while &#x5FAA;&#x73AF;&#x4E2D;&#x4F1A;&#x9047;&#x5230;&#x56DB;&#x79CD;&#x60C5;&#x51B5;&#xFF1A;</p>
<p>&#x60C5;&#x5F62;&#x4E00;&#xFF1A;&#x5F53;&#x65B0;&#x8001; VNode &#x8282;&#x70B9;&#x7684; start &#x662F;&#x540C;&#x4E00;&#x8282;&#x70B9;&#x65F6;&#xFF0C;&#x76F4;&#x63A5; patchVnode &#x5373;&#x53EF;&#xFF0C;&#x540C;&#x65F6;&#x65B0;&#x8001; VNode &#x8282;&#x70B9;&#x7684;&#x5F00;&#x59CB;&#x7D22;&#x5F15;&#x90FD;&#x52A0; 1&#x3002;</p>
<p>&#x60C5;&#x5F62;&#x4E8C;&#xFF1A;&#x5F53;&#x65B0;&#x8001; VNode &#x8282;&#x70B9;&#x7684; end &#x662F;&#x540C;&#x4E00;&#x8282;&#x70B9;&#x65F6;&#xFF0C;&#x76F4;&#x63A5; patchVnode &#x5373;&#x53EF;&#xFF0C;&#x540C;&#x65F6;&#x65B0;&#x8001; VNode &#x8282;&#x70B9;&#x7684;&#x7ED3;&#x675F;&#x7D22;&#x5F15;&#x90FD;&#x51CF; 1&#x3002;</p>
<p>&#x60C5;&#x5F62;&#x4E09;&#xFF1A;&#x5F53;&#x8001; VNode &#x8282;&#x70B9;&#x7684; start &#x548C;&#x65B0; VNode &#x8282;&#x70B9;&#x7684; end &#x662F;&#x540C;&#x4E00;&#x8282;&#x70B9;&#x65F6;&#xFF0C;&#x8FD9;&#x8BF4;&#x660E;&#x8FD9;&#x6B21;&#x6570;&#x636E;&#x66F4;&#x65B0;&#x540E; oldStartVnode &#x5DF2;&#x7ECF;&#x8DD1;&#x5230;&#x4E86; oldEndVnode &#x540E;&#x9762;&#x53BB;&#x4E86;&#x3002;&#x8FD9;&#x65F6;&#x5019;&#x5728; patchVnode &#x540E;&#xFF0C;&#x8FD8;&#x9700;&#x8981;&#x5C06;&#x5F53;&#x524D;&#x771F;&#x5B9E; dom &#x8282;&#x70B9;&#x79FB;&#x52A8;&#x5230; oldEndVnode &#x7684;&#x540E;&#x9762;&#xFF0C;&#x540C;&#x65F6;&#x8001; VNode &#x8282;&#x70B9;&#x5F00;&#x59CB;&#x7D22;&#x5F15;&#x52A0; 1&#xFF0C;&#x65B0; VNode &#x8282;&#x70B9;&#x7684;&#x7ED3;&#x675F;&#x7D22;&#x5F15;&#x51CF; 1&#x3002;</p>
<p>&#x60C5;&#x5F62;&#x56DB;&#xFF1A;&#x5F53;&#x8001; VNode &#x8282;&#x70B9;&#x7684; end &#x548C;&#x65B0; VNode &#x8282;&#x70B9;&#x7684; start &#x662F;&#x540C;&#x4E00;&#x8282;&#x70B9;&#x65F6;&#xFF0C;&#x8FD9;&#x8BF4;&#x660E;&#x8FD9;&#x6B21;&#x6570;&#x636E;&#x66F4;&#x65B0;&#x540E; oldEndVnode &#x8DD1;&#x5230;&#x4E86; oldStartVnode &#x7684;&#x524D;&#x9762;&#x53BB;&#x4E86;&#x3002;&#x8FD9;&#x65F6;&#x5019;&#x5728; patchVnode &#x540E;&#xFF0C;&#x8FD8;&#x9700;&#x8981;&#x5C06;&#x5F53;&#x524D;&#x771F;&#x5B9E; dom &#x8282;&#x70B9;&#x79FB;&#x52A8;&#x5230; oldStartVnode &#x7684;&#x524D;&#x9762;&#xFF0C;&#x540C;&#x65F6;&#x8001; VNode &#x8282;&#x70B9;&#x7ED3;&#x675F;&#x7D22;&#x5F15;&#x51CF; 1&#xFF0C;&#x65B0; VNode &#x8282;&#x70B9;&#x7684;&#x5F00;&#x59CB;&#x7D22;&#x5F15;&#x52A0; 1&#x3002;</p>
<p>while &#x5FAA;&#x73AF;&#x7684;&#x9000;&#x51FA;&#x6761;&#x4EF6;&#x662F;&#x76F4;&#x5230;&#x8001;&#x8282;&#x70B9;&#x6216;&#x8005;&#x65B0;&#x8282;&#x70B9;&#x7684;&#x5F00;&#x59CB;&#x4F4D;&#x7F6E;&#x5927;&#x4E8E;&#x7ED3;&#x675F;&#x4F4D;&#x7F6E;&#x3002;</p>
<p>&#x60C5;&#x5F62;&#x4E00;&#xFF1A;&#x5982;&#x679C;&#x5728;&#x5FAA;&#x73AF;&#x4E2D;&#xFF0C;oldStartIdx&#x5927;&#x4E8E;oldEndIdx&#x4E86;&#xFF0C;&#x90A3;&#x5C31;&#x8868;&#x793A;oldChildren&#x6BD4;newChildren&#x5148;&#x5FAA;&#x73AF;&#x5B8C;&#x6BD5;&#xFF0C;&#x90A3;&#x4E48;newChildren&#x91CC;&#x9762;&#x5269;&#x4F59;&#x7684;&#x8282;&#x70B9;&#x90FD;&#x662F;&#x9700;&#x8981;&#x65B0;&#x589E;&#x7684;&#x8282;&#x70B9;&#xFF0C;&#x628A;[newStartIdx, newEndIdx]&#x4E4B;&#x95F4;&#x7684;&#x6240;&#x6709;&#x8282;&#x70B9;&#x90FD;&#x63D2;&#x5165;&#x5230;DOM&#x4E2D;</p>
<p>&#x60C5;&#x5F62;&#x4E8C;&#xFF1A;&#x5982;&#x679C;&#x5728;&#x5FAA;&#x73AF;&#x4E2D;&#xFF0C;newStartIdx&#x5927;&#x4E8E;newEndIdx&#x4E86;&#xFF0C;&#x90A3;&#x5C31;&#x8868;&#x793A;newChildren&#x6BD4;oldChildren&#x5148;&#x5FAA;&#x73AF;&#x5B8C;&#x6BD5;&#xFF0C;&#x90A3;&#x4E48;oldChildren&#x91CC;&#x9762;&#x5269;&#x4F59;&#x7684;&#x8282;&#x70B9;&#x90FD;&#x662F;&#x9700;&#x8981;&#x5220;&#x9664;&#x7684;&#x8282;&#x70B9;&#xFF0C;&#x628A;[oldStartIdx, oldEndIdx]&#x4E4B;&#x95F4;&#x7684;&#x6240;&#x6709;&#x8282;&#x70B9;&#x90FD;&#x5220;&#x9664;</p>
<h5 id="66-&#x2605;&#x2605;&#x2605;-&#x600E;&#x4E48;&#x4FEE;&#x6539;vuex&#x4E2D;&#x7684;&#x72B6;&#x6001;&#xFF1F;vuex&#x4E2D;&#x6709;&#x54EA;&#x4E9B;&#x65B9;&#x6CD5;"><a name="66-&#x2605;&#x2605;&#x2605;-&#x600E;&#x4E48;&#x4FEE;&#x6539;vuex&#x4E2D;&#x7684;&#x72B6;&#x6001;&#xFF1F;vuex&#x4E2D;&#x6709;&#x54EA;&#x4E9B;&#x65B9;&#x6CD5;" class="anchor-navigation-ex-anchor" href="#66-&#x2605;&#x2605;&#x2605;-&#x600E;&#x4E48;&#x4FEE;&#x6539;vuex&#x4E2D;&#x7684;&#x72B6;&#x6001;&#xFF1F;vuex&#x4E2D;&#x6709;&#x54EA;&#x4E9B;&#x65B9;&#x6CD5;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="66-&#x2605;&#x2605;&#x2605;-&#x600E;&#x4E48;&#x4FEE;&#x6539;vuex&#x4E2D;&#x7684;&#x72B6;&#x6001;&#xFF1F;vuex&#x4E2D;&#x6709;&#x54EA;&#x4E9B;&#x65B9;&#x6CD5;" class="plugin-anchor" href="#66-&#x2605;&#x2605;&#x2605;-&#x600E;&#x4E48;&#x4FEE;&#x6539;vuex&#x4E2D;&#x7684;&#x72B6;&#x6001;&#xFF1F;vuex&#x4E2D;&#x6709;&#x54EA;&#x4E9B;&#x65B9;&#x6CD5;"><i class="fa fa-link" aria-hidden="true"></i></a>66. &#x2605;&#x2605;&#x2605; &#x600E;&#x4E48;&#x4FEE;&#x6539;Vuex&#x4E2D;&#x7684;&#x72B6;&#x6001;&#xFF1F;Vuex&#x4E2D;&#x6709;&#x54EA;&#x4E9B;&#x65B9;&#x6CD5;</h5>
<ul>
<li>&#x901A;&#x8FC7;<strong>this.$store.state.&#x5C5E;&#x6027;</strong> &#x7684;&#x65B9;&#x6CD5;&#x6765;&#x8BBF;&#x95EE;&#x72B6;&#x6001;</li>
<li>&#x901A;&#x8FC7;<strong>this.$store.commit(&#x2018;mutation&#x4E2D;&#x7684;&#x65B9;&#x6CD5;&#x2019;)</strong> &#x6765;&#x4FEE;&#x6539;&#x72B6;&#x6001;</li>
</ul>
<h5 id="67-&#x2605;&#x2605;&#x2605;-vue-router&#x8DEF;&#x7531;&#x4F20;&#x53C2;&#x7684;&#x65B9;&#x5F0F;"><a name="67-&#x2605;&#x2605;&#x2605;-vue-router&#x8DEF;&#x7531;&#x4F20;&#x53C2;&#x7684;&#x65B9;&#x5F0F;" class="anchor-navigation-ex-anchor" href="#67-&#x2605;&#x2605;&#x2605;-vue-router&#x8DEF;&#x7531;&#x4F20;&#x53C2;&#x7684;&#x65B9;&#x5F0F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="67-&#x2605;&#x2605;&#x2605;-vue-router&#x8DEF;&#x7531;&#x4F20;&#x53C2;&#x7684;&#x65B9;&#x5F0F;" class="plugin-anchor" href="#67-&#x2605;&#x2605;&#x2605;-vue-router&#x8DEF;&#x7531;&#x4F20;&#x53C2;&#x7684;&#x65B9;&#x5F0F;"><i class="fa fa-link" aria-hidden="true"></i></a>67. &#x2605;&#x2605;&#x2605; vue-router&#x8DEF;&#x7531;&#x4F20;&#x53C2;&#x7684;&#x65B9;&#x5F0F;</h5>
<p>1&#x3001;&#x8DEF;&#x7531;&#x4F20;&#x53C2;</p>
<ol>
<li><p>query</p>
<pre><code class="lang-js"><span class="hljs-comment">// &#x65B9;&#x6CD5;&#x4E00;</span>
&lt;template&gt;
    <span class="xml"><span class="hljs-tag">&lt;<span class="hljs-name">router-link</span>
          <span class="hljs-attr">:to</span>=<span class="hljs-string">&quot;{
                  path: &apos;blogDetail&apos;,
                  query: { id: item.id, views: item.views }
                }&quot;</span>
          <span class="hljs-attr">tag</span>=<span class="hljs-string">&quot;h2&quot;</span>
        &gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">router-link</span>&gt;</span>
<span class="hljs-tag">&lt;/<span class="hljs-name">template</span>&gt;</span></span>

<span class="hljs-comment">// &#x65B9;&#x6CD5;&#x4E8C;</span>
<span class="hljs-keyword">this</span>.$router.push({  
  path: <span class="hljs-string">&apos;blogDetail&apos;</span>, 
  query: { 
    id: item.id,
    views: item.views
  }
})
</code></pre>
</li>
<li><p>params</p>
<pre><code class="lang-js">&lt;template&gt;
    <span class="xml"><span class="hljs-tag">&lt;<span class="hljs-name">router-link</span>
          <span class="hljs-attr">:to</span>=<span class="hljs-string">&quot;{
                  name: &apos;blogDetail&apos;,
                  params: { id: item.id, views: item.views }
                }&quot;</span>
          <span class="hljs-attr">tag</span>=<span class="hljs-string">&quot;h2&quot;</span>
        &gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">router-link</span>&gt;</span>
<span class="hljs-tag">&lt;/<span class="hljs-name">template</span>&gt;</span></span>

<span class="hljs-keyword">this</span>.$router.push({  
  name: <span class="hljs-string">&apos;blogDetail&apos;</span>, 
  params: { 
    id: item.id,
    views: item.views
  }
})
</code></pre>
</li>
</ol>
<h5 id="68-&#x2605;&#x2605;&#x2605;-hash-history&#x533A;&#x522B;&#xFF0C;&#x600E;&#x4E48;&#x53BB;&#x89E3;&#x51B3;history&#x56DE;&#x9000;&#x95EE;&#x9898;"><a name="68-&#x2605;&#x2605;&#x2605;-hash-history&#x533A;&#x522B;&#xFF0C;&#x600E;&#x4E48;&#x53BB;&#x89E3;&#x51B3;history&#x56DE;&#x9000;&#x95EE;&#x9898;" class="anchor-navigation-ex-anchor" href="#68-&#x2605;&#x2605;&#x2605;-hash-history&#x533A;&#x522B;&#xFF0C;&#x600E;&#x4E48;&#x53BB;&#x89E3;&#x51B3;history&#x56DE;&#x9000;&#x95EE;&#x9898;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="68-&#x2605;&#x2605;&#x2605;-hash-history&#x533A;&#x522B;&#xFF0C;&#x600E;&#x4E48;&#x53BB;&#x89E3;&#x51B3;history&#x56DE;&#x9000;&#x95EE;&#x9898;" class="plugin-anchor" href="#68-&#x2605;&#x2605;&#x2605;-hash-history&#x533A;&#x522B;&#xFF0C;&#x600E;&#x4E48;&#x53BB;&#x89E3;&#x51B3;history&#x56DE;&#x9000;&#x95EE;&#x9898;"><i class="fa fa-link" aria-hidden="true"></i></a>68. &#x2605;&#x2605;&#x2605; hash history&#x533A;&#x522B;&#xFF0C;&#x600E;&#x4E48;&#x53BB;&#x89E3;&#x51B3;history&#x56DE;&#x9000;&#x95EE;&#x9898;</h5>
<table>
<thead>
<tr>
<th></th>
<th>hash</th>
<th>history</th>
</tr>
</thead>
<tbody>
<tr>
<td>url&#x663E;&#x793A;</td>
<td>&#x6709;#&#xFF0C;&#x5F88;Low</td>
<td>&#x65E0;#&#xFF0C;&#x597D;&#x770B;</td>
</tr>
<tr>
<td>&#x56DE;&#x8F66;&#x5237;&#x65B0;</td>
<td>&#x53EF;&#x4EE5;&#x52A0;&#x8F7D;&#x5230;hash&#x503C;&#x5BF9;&#x5E94;&#x9875;&#x9762;</td>
<td>&#x4E00;&#x822C;&#x5C31;&#x662F;404&#x6389;&#x4E86;</td>
</tr>
<tr>
<td>&#x652F;&#x6301;&#x7248;&#x672C;</td>
<td>&#x652F;&#x6301;&#x4F4E;&#x7248;&#x672C;&#x6D4F;&#x89C8;&#x5668;&#x548C;IE&#x6D4F;&#x89C8;&#x5668;</td>
<td>HTML5&#x65B0;&#x63A8;&#x51FA;&#x7684;API</td>
</tr>
</tbody>
</table>
<h5 id="69-&#x2605;&#x2605;&#x2605;-&#x7528;&#x8FC7;beforeeach&#x5417;&#xFF1F;"><a name="69-&#x2605;&#x2605;&#x2605;-&#x7528;&#x8FC7;beforeeach&#x5417;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#69-&#x2605;&#x2605;&#x2605;-&#x7528;&#x8FC7;beforeeach&#x5417;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="69-&#x2605;&#x2605;&#x2605;-&#x7528;&#x8FC7;beforeeach&#x5417;&#xFF1F;" class="plugin-anchor" href="#69-&#x2605;&#x2605;&#x2605;-&#x7528;&#x8FC7;beforeeach&#x5417;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>69. &#x2605;&#x2605;&#x2605; &#x7528;&#x8FC7;beforeEach&#x5417;&#xFF1F;</h5>
<p>&#x6BCF;&#x6B21;&#x901A;&#x8FC7;vue-router&#x8FDB;&#x884C;&#x9875;&#x9762;&#x8DF3;&#x8F6C;&#xFF0C;&#x90FD;&#x4F1A;&#x89E6;&#x53D1;beforeEach&#x8FD9;&#x4E2A;&#x94A9;&#x5B50;&#x51FD;&#x6570;&#xFF0C;&#x8FD9;&#x4E2A;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#x5171;&#x6709;&#x4E09;&#x4E2A;&#x53C2;&#x6570;&#xFF0C;to&#xFF0C;from&#xFF0C;next&#x8FD9;&#x4E09;&#x4E2A;&#x53C2;&#x6570;&#xFF0C;to&#x8868;&#x793A;&#x6211;&#x8981;&#x8DF3;&#x8F6C;&#x7684;&#x76EE;&#x6807;&#x8DEF;&#x7531;&#x5BF9;&#x5E94;&#x7684;&#x53C2;&#x6570;&#xFF0C;from&#x8868;&#x793A;&#x6765;&#x81EA;&#x90A3;&#x4E2A;&#x8DEF;&#x7531;&#xFF0C;&#x5C31;&#x662F;&#x64CD;&#x4F5C;&#x8DEF;&#x7531;&#x8DF3;&#x8F6C;&#x4E4B;&#x524D;&#x7684;&#xFF0C;&#x5373;&#x5C06;&#x79BB;&#x5F00;&#x7684;&#x8DEF;&#x7531;&#x5BF9;&#x5E94;&#x7684;&#x53C2;&#x6570;&#xFF0C;next&#x662F;&#x4E00;&#x4E2A;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#xFF0C;&#x4E00;&#x5B9A;&#x8981;&#x8C03;&#x7528;next&#x65B9;&#x6CD5;&#x6765;resolve&#x8FD9;&#x4E2A;&#x94A9;&#x5B50;&#x51FD;&#x6570;&#xFF1B;</p>
<h5 id="70-&#x2605;&#x2605;&#x2605;-jquery&#x5199;&#x7684;&#x9875;&#x9762;&#xFF0C;&#x5207;&#x6362;&#x5230;vue&#x7684;&#x9875;&#x9762;&#xFF0C;&#x6709;&#x5361;&#x987F;&#x5417;&#xFF1F;"><a name="70-&#x2605;&#x2605;&#x2605;-jquery&#x5199;&#x7684;&#x9875;&#x9762;&#xFF0C;&#x5207;&#x6362;&#x5230;vue&#x7684;&#x9875;&#x9762;&#xFF0C;&#x6709;&#x5361;&#x987F;&#x5417;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#70-&#x2605;&#x2605;&#x2605;-jquery&#x5199;&#x7684;&#x9875;&#x9762;&#xFF0C;&#x5207;&#x6362;&#x5230;vue&#x7684;&#x9875;&#x9762;&#xFF0C;&#x6709;&#x5361;&#x987F;&#x5417;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="70-&#x2605;&#x2605;&#x2605;-jquery&#x5199;&#x7684;&#x9875;&#x9762;&#xFF0C;&#x5207;&#x6362;&#x5230;vue&#x7684;&#x9875;&#x9762;&#xFF0C;&#x6709;&#x5361;&#x987F;&#x5417;&#xFF1F;" class="plugin-anchor" href="#70-&#x2605;&#x2605;&#x2605;-jquery&#x5199;&#x7684;&#x9875;&#x9762;&#xFF0C;&#x5207;&#x6362;&#x5230;vue&#x7684;&#x9875;&#x9762;&#xFF0C;&#x6709;&#x5361;&#x987F;&#x5417;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>70. &#x2605;&#x2605;&#x2605; jQuery&#x5199;&#x7684;&#x9875;&#x9762;&#xFF0C;&#x5207;&#x6362;&#x5230;vue&#x7684;&#x9875;&#x9762;&#xFF0C;&#x6709;&#x5361;&#x987F;&#x5417;&#xFF1F;</h5>
<h5 id="71-&#x2605;&#x2605;&#x2605;-vnode&#x7684;&#x7F3A;&#x70B9;"><a name="71-&#x2605;&#x2605;&#x2605;-vnode&#x7684;&#x7F3A;&#x70B9;" class="anchor-navigation-ex-anchor" href="#71-&#x2605;&#x2605;&#x2605;-vnode&#x7684;&#x7F3A;&#x70B9;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="71-&#x2605;&#x2605;&#x2605;-vnode&#x7684;&#x7F3A;&#x70B9;" class="plugin-anchor" href="#71-&#x2605;&#x2605;&#x2605;-vnode&#x7684;&#x7F3A;&#x70B9;"><i class="fa fa-link" aria-hidden="true"></i></a>71. &#x2605;&#x2605;&#x2605; Vnode&#x7684;&#x7F3A;&#x70B9;</h5>
<h5 id="72-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;&#x7684;&#x5355;&#x9879;&#x6570;&#x636E;&#x6D41;"><a name="72-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;&#x7684;&#x5355;&#x9879;&#x6570;&#x636E;&#x6D41;" class="anchor-navigation-ex-anchor" href="#72-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;&#x7684;&#x5355;&#x9879;&#x6570;&#x636E;&#x6D41;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="72-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;&#x7684;&#x5355;&#x9879;&#x6570;&#x636E;&#x6D41;" class="plugin-anchor" href="#72-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;&#x7684;&#x5355;&#x9879;&#x6570;&#x636E;&#x6D41;"><i class="fa fa-link" aria-hidden="true"></i></a>72. &#x2605;&#x2605;&#x2605; Vue&#x4E2D;&#x7684;&#x5355;&#x9879;&#x6570;&#x636E;&#x6D41;</h5>
<p> &#x5355;&#x5411;&#x6570;&#x636E;&#x6D41;&#x6307;&#x53EA;&#x80FD;&#x4ECE;&#x4E00;&#x4E2A;&#x65B9;&#x5411;&#x6765;&#x4FEE;&#x6539;&#x72B6;&#x6001;&#x3002; </p>
<p>&#x6570;&#x636E;&#x4ECE;&#x7236;&#x7EA7;&#x7EC4;&#x4EF6;&#x4F20;&#x9012;&#x7ED9;&#x5B50;&#x7EC4;&#x4EF6;&#xFF0C;&#x53EA;&#x80FD;&#x5355;&#x5411;&#x7ED1;&#x5B9A;&#x3002;</p>
<p>&#x5B50;&#x7EC4;&#x4EF6;&#x5185;&#x90E8;&#x4E0D;&#x80FD;&#x76F4;&#x63A5;&#x4FEE;&#x6539;&#x4ECE;&#x7236;&#x7EA7;&#x4F20;&#x9012;&#x8FC7;&#x6765;&#x7684;&#x6570;&#x636E;&#x3002;</p>
<h5 id="73-&#x2605;&#x2605;&#x2605;-vue&#x7EC4;&#x4EF6;&#x4E2D;&#x7684;data&#x4E3A;&#x4EC0;&#x4E48;&#x662F;&#x51FD;&#x6570;&#xFF0C;&#x6839;&#x7EC4;&#x4EF6;&#x5374;&#x662F;&#x5BF9;&#x8C61;&#x5462;&#xFF1F;"><a name="73-&#x2605;&#x2605;&#x2605;-vue&#x7EC4;&#x4EF6;&#x4E2D;&#x7684;data&#x4E3A;&#x4EC0;&#x4E48;&#x662F;&#x51FD;&#x6570;&#xFF0C;&#x6839;&#x7EC4;&#x4EF6;&#x5374;&#x662F;&#x5BF9;&#x8C61;&#x5462;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#73-&#x2605;&#x2605;&#x2605;-vue&#x7EC4;&#x4EF6;&#x4E2D;&#x7684;data&#x4E3A;&#x4EC0;&#x4E48;&#x662F;&#x51FD;&#x6570;&#xFF0C;&#x6839;&#x7EC4;&#x4EF6;&#x5374;&#x662F;&#x5BF9;&#x8C61;&#x5462;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="73-&#x2605;&#x2605;&#x2605;-vue&#x7EC4;&#x4EF6;&#x4E2D;&#x7684;data&#x4E3A;&#x4EC0;&#x4E48;&#x662F;&#x51FD;&#x6570;&#xFF0C;&#x6839;&#x7EC4;&#x4EF6;&#x5374;&#x662F;&#x5BF9;&#x8C61;&#x5462;&#xFF1F;" class="plugin-anchor" href="#73-&#x2605;&#x2605;&#x2605;-vue&#x7EC4;&#x4EF6;&#x4E2D;&#x7684;data&#x4E3A;&#x4EC0;&#x4E48;&#x662F;&#x51FD;&#x6570;&#xFF0C;&#x6839;&#x7EC4;&#x4EF6;&#x5374;&#x662F;&#x5BF9;&#x8C61;&#x5462;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>73. &#x2605;&#x2605;&#x2605; Vue&#x7EC4;&#x4EF6;&#x4E2D;&#x7684;Data&#x4E3A;&#x4EC0;&#x4E48;&#x662F;&#x51FD;&#x6570;&#xFF0C;&#x6839;&#x7EC4;&#x4EF6;&#x5374;&#x662F;&#x5BF9;&#x8C61;&#x5462;&#xFF1F;</h5>
<p>&#x7EFC;&#x4E0A;&#x53EF;&#x77E5;&#xFF0C;&#x5982;&#x679C;data&#x662F;&#x4E00;&#x4E2A;&#x51FD;&#x6570;&#x7684;&#x8BDD;&#xFF0C;&#x8FD9;&#x6837;&#x6BCF;&#x590D;&#x7528;&#x4E00;&#x6B21;&#x7EC4;&#x4EF6;&#xFF0C;&#x5C31;&#x4F1A;&#x8FD4;&#x56DE;&#x4E00;&#x4EFD;&#x65B0;&#x7684;data&#xFF0C;&#x7C7B;&#x4F3C;&#x4E8E;&#x7ED9;&#x6BCF;&#x4E2A;&#x7EC4;&#x4EF6;&#x5B9E;&#x4F8B;&#x521B;&#x5EFA;&#x4E00;&#x4E2A;&#x79C1;&#x6709;&#x7684;&#x6570;&#x636E;&#x7A7A;&#x95F4;&#xFF0C;&#x8BA9;&#x5404;&#x4E2A;&#x7EC4;&#x4EF6;&#x5B9E;&#x4F8B;&#x7EF4;&#x62A4;&#x5404;&#x81EA;&#x7684;&#x6570;&#x636E;&#x3002;&#x800C;&#x5355;&#x7EAF;&#x7684;&#x5199;&#x6210;&#x5BF9;&#x8C61;&#x5F62;&#x5F0F;&#xFF0C;&#x5C31;&#x4F7F;&#x5F97;&#x6240;&#x6709;&#x7EC4;&#x4EF6;&#x5B9E;&#x4F8B;&#x5171;&#x7528;&#x4E86;&#x4E00;&#x4EFD;data&#xFF0C;&#x5C31;&#x4F1A;&#x9020;&#x6210;&#x4E00;&#x4E2A;&#x53D8;&#x4E86;&#x5168;&#x90FD;&#x4F1A;&#x53D8;&#x7684;&#x7ED3;&#x679C;&#x3002;</p>
<p>&#x6240;&#x4EE5;&#x8BF4;vue&#x7EC4;&#x4EF6;&#x7684;data&#x5FC5;&#x987B;&#x662F;&#x51FD;&#x6570;&#x3002;&#x8FD9;&#x90FD;&#x662F;&#x56E0;&#x4E3A;js&#x7684;&#x7279;&#x6027;&#x5E26;&#x6765;&#x7684;&#xFF0C;&#x8DDF;vue&#x672C;&#x8EAB;&#x8BBE;&#x8BA1;&#x65E0;&#x5173;&#x3002;</p>
<h5 id="74-&#x2605;&#x2605;&#x2605;-&#x4F60;&#x505A;&#x8FC7;&#x54EA;&#x4E9B;vue&#x7684;&#x6027;&#x80FD;&#x4F18;&#x5316;&#xFF1F;"><a name="74-&#x2605;&#x2605;&#x2605;-&#x4F60;&#x505A;&#x8FC7;&#x54EA;&#x4E9B;vue&#x7684;&#x6027;&#x80FD;&#x4F18;&#x5316;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#74-&#x2605;&#x2605;&#x2605;-&#x4F60;&#x505A;&#x8FC7;&#x54EA;&#x4E9B;vue&#x7684;&#x6027;&#x80FD;&#x4F18;&#x5316;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="74-&#x2605;&#x2605;&#x2605;-&#x4F60;&#x505A;&#x8FC7;&#x54EA;&#x4E9B;vue&#x7684;&#x6027;&#x80FD;&#x4F18;&#x5316;&#xFF1F;" class="plugin-anchor" href="#74-&#x2605;&#x2605;&#x2605;-&#x4F60;&#x505A;&#x8FC7;&#x54EA;&#x4E9B;vue&#x7684;&#x6027;&#x80FD;&#x4F18;&#x5316;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>74. &#x2605;&#x2605;&#x2605; &#x4F60;&#x505A;&#x8FC7;&#x54EA;&#x4E9B;Vue&#x7684;&#x6027;&#x80FD;&#x4F18;&#x5316;&#xFF1F;</h5>
<p>1&#x3001;&#x9996;&#x5C4F;&#x52A0;&#x8F7D;&#x4F18;&#x5316;</p>
<p>2&#x3001;&#x8DEF;&#x7531;&#x61D2;&#x52A0;&#x8F7D;</p>
<pre><code class="lang-js">{      
  path: <span class="hljs-string">&apos;/&apos;</span>,      
  name: <span class="hljs-string">&apos;home&apos;</span>,      
  component: () =&gt; <span class="hljs-keyword">import</span>(<span class="hljs-string">&apos;./views/home/index.vue&apos;</span>),      
  meta: { isShowHead: <span class="hljs-literal">true</span> }
}
</code></pre>
<p>3&#x3001;&#x5F00;&#x542F;&#x670D;&#x52A1;&#x5668; Gzip</p>
<p> &#x5F00;&#x542F; Gzip &#x5C31;&#x662F;&#x4E00;&#x79CD;&#x538B;&#x7F29;&#x6280;&#x672F;&#xFF0C;&#x9700;&#x8981;&#x524D;&#x7AEF;&#x63D0;&#x4F9B;&#x538B;&#x7F29;&#x5305;&#xFF0C;&#x7136;&#x540E;&#x5728;&#x670D;&#x52A1;&#x5668;&#x5F00;&#x542F;&#x538B;&#x7F29;&#xFF0C;&#x6587;&#x4EF6;&#x5728;&#x670D;&#x52A1;&#x5668;&#x538B;&#x7F29;&#x540E;&#x4F20;&#x7ED9;&#x6D4F;&#x89C8;&#x5668;&#xFF0C;&#x6D4F;&#x89C8;&#x5668;&#x89E3;&#x538B;&#x540E;&#x8FDB;&#x884C;&#x518D;&#x8FDB;&#x884C;&#x89E3;&#x6790;&#x3002;&#x9996;&#x5148;&#x5B89;&#x88C5; webpack &#x63D0;&#x4F9B;&#x7684;<code>compression-webpack-plugin</code>&#x8FDB;&#x884C;&#x538B;&#x7F29;,&#x7136;&#x540E;&#x5728; vue.config.js&#xFF1A; </p>
<pre><code class="lang-js"><span class="hljs-keyword">const</span> CompressionWebpackPlugin = <span class="hljs-built_in">require</span>(<span class="hljs-string">&apos;compression-webpack-plugin&apos;</span>)
<span class="hljs-keyword">const</span> productionGzipExtensions = [<span class="hljs-string">&apos;js&apos;</span>, <span class="hljs-string">&apos;css&apos;</span>]......plugins: [      
  <span class="hljs-keyword">new</span> CompressionWebpackPlugin(
    {        
      algorithm: <span class="hljs-string">&apos;gzip&apos;</span>,        
      test:     <span class="hljs-keyword">new</span> <span class="hljs-built_in">RegExp</span>(<span class="hljs-string">&apos;\\.(&apos;</span> + productionGzipExtensions.join(<span class="hljs-string">&apos;|&apos;</span>) +                 <span class="hljs-string">&apos;)$&apos;</span>),            
      threshold: <span class="hljs-number">10240</span>,        
      minRatio: <span class="hljs-number">0.8</span>      
       }
)]....
</code></pre>
<p>4&#x3001;&#x542F;&#x52A8; CDN &#x52A0;&#x901F;</p>
<p>&#x6211;&#x4EEC;&#x7EE7;&#x7EED;&#x91C7;&#x7528; cdn &#x7684;&#x65B9;&#x5F0F;&#x6765;&#x5F15;&#x5165;&#x4E00;&#x4E9B;&#x7B2C;&#x4E09;&#x65B9;&#x8D44;&#x6E90;&#xFF0C;&#x5C31;&#x53EF;&#x4EE5;&#x7F13;&#x89E3;&#x6211;&#x4EEC;&#x670D;&#x52A1;&#x5668;&#x7684;&#x538B;&#x529B;&#xFF0C;&#x539F;&#x7406;&#x662F;&#x5C06;&#x6211;&#x4EEC;&#x7684;&#x538B;&#x529B;&#x5206;&#x7ED9;&#x5176;&#x4ED6;&#x670D;&#x52A1;&#x5668;&#x70B9;&#x3002;</p>
<p>5&#x3001;&#x4EE3;&#x7801;&#x5C42;&#x9762;&#x4F18;&#x5316; </p>
<ul>
<li>computed &#x548C; watch &#x533A;&#x5206;&#x4F7F;&#x7528;&#x573A;&#x666F;<pre><code>computed&#xFF1A; &#x662F;&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#xFF0C;&#x4F9D;&#x8D56;&#x5176;&#x5B83;&#x5C5E;&#x6027;&#x503C;&#xFF0C;&#x5E76;&#x4E14; computed &#x7684;&#x503C;&#x6709;&#x7F13;&#x5B58;&#xFF0C;&#x53EA;&#x6709;&#x5B83;&#x4F9D;&#x8D56;&#x7684;&#x5C5E;&#x6027;&#x503C;&#x53D1;&#x751F;&#x6539;&#x53D8;&#xFF0C;&#x4E0B;&#x4E00;&#x6B21;&#x83B7;&#x53D6; computed &#x7684;&#x503C;&#x65F6;&#x624D;&#x4F1A;&#x91CD;&#x65B0;&#x8BA1;&#x7B97; computed &#x7684;&#x503C;&#x3002;&#x5F53;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x8FDB;&#x884C;&#x6570;&#x503C;&#x8BA1;&#x7B97;&#xFF0C;&#x5E76;&#x4E14;&#x4F9D;&#x8D56;&#x4E8E;&#x5176;&#x5B83;&#x6570;&#x636E;&#x65F6;&#xFF0C;&#x5E94;&#x8BE5;&#x4F7F;&#x7528; computed&#xFF0C;&#x56E0;&#x4E3A;&#x53EF;&#x4EE5;&#x5229;&#x7528; computed &#x7684;&#x7F13;&#x5B58;&#x7279;&#x6027;&#xFF0C;&#x907F;&#x514D;&#x6BCF;&#x6B21;&#x83B7;&#x53D6;&#x503C;&#x65F6;&#xFF0C;&#x90FD;&#x8981;&#x91CD;&#x65B0;&#x8BA1;&#x7B97;&#xFF1B;
  watch&#xFF1A;&#x7C7B;&#x4F3C;&#x4E8E;&#x67D0;&#x4E9B;&#x6570;&#x636E;&#x7684;&#x76D1;&#x542C;&#x56DE;&#x8C03; &#xFF0C;&#x6BCF;&#x5F53;&#x76D1;&#x542C;&#x7684;&#x6570;&#x636E;&#x53D8;&#x5316;&#x65F6;&#x90FD;&#x4F1A;&#x6267;&#x884C;&#x56DE;&#x8C03;&#x8FDB;&#x884C;&#x540E;&#x7EED;&#x64CD;&#x4F5C;&#xFF1B;&#x5F53;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x5728;&#x6570;&#x636E;&#x53D8;&#x5316;&#x65F6;&#x6267;&#x884C;&#x5F02;&#x6B65;&#x6216;&#x5F00;&#x9500;&#x8F83;&#x5927;&#x7684;&#x64CD;&#x4F5C;&#x65F6;&#xFF0C;&#x5E94;&#x8BE5;&#x4F7F;&#x7528; watch&#xFF0C;&#x4F7F;&#x7528; watch &#x9009;&#x9879;&#x5141;&#x8BB8;&#x6211;&#x4EEC;&#x6267;&#x884C;&#x5F02;&#x6B65;&#x64CD;&#x4F5C; ( &#x8BBF;&#x95EE;&#x4E00;&#x4E2A; API )&#xFF0C;&#x9650;&#x5236;&#x6211;&#x4EEC;&#x6267;&#x884C;&#x8BE5;&#x64CD;&#x4F5C;&#x7684;&#x9891;&#x7387;&#xFF0C;&#x5E76;&#x5728;&#x6211;&#x4EEC;&#x5F97;&#x5230;&#x6700;&#x7EC8;&#x7ED3;&#x679C;&#x524D;&#xFF0C;&#x8BBE;&#x7F6E;&#x4E2D;&#x95F4;&#x72B6;&#x6001;&#x3002;&#x8FD9;&#x4E9B;&#x90FD;&#x662F;&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#x65E0;&#x6CD5;&#x505A;&#x5230;&#x7684;&#x3002;
</code></pre></li>
<li>v-if &#x548C; v-show &#x533A;&#x5206;&#x4F7F;&#x7528;&#x573A;&#x666F;
v-if &#x9002;&#x7528;&#x4E8E;&#x5728;&#x8FD0;&#x884C;&#x65F6;&#x5F88;&#x5C11;&#x6539;&#x53D8;&#x6761;&#x4EF6;&#xFF0C;&#x4E0D;&#x9700;&#x8981;&#x9891;&#x7E41;&#x5207;&#x6362;&#x6761;&#x4EF6;&#x7684;&#x573A;&#x666F;&#xFF1B;v-show &#x5219;&#x9002;&#x7528;&#x4E8E;&#x9700;&#x8981;&#x975E;&#x5E38;&#x9891;&#x7E41;&#x5207;&#x6362;&#x6761;&#x4EF6;&#x7684;&#x573A;&#x666F;&#x3002;&#x8FD9;&#x91CC;&#x8981;&#x8BF4;&#x7684;&#x4F18;&#x5316;&#x70B9;&#x5728;&#x4E8E;&#x51CF;&#x5C11;&#x9875;&#x9762;&#x4E2D; dom &#x603B;&#x6570;&#xFF0C;&#x6211;&#x6BD4;&#x8F83;&#x503E;&#x5411;&#x4E8E;&#x4F7F;&#x7528; v-if&#xFF0C;&#x56E0;&#x4E3A;&#x51CF;&#x5C11;&#x4E86; dom &#x6570;&#x91CF;&#x3002;</li>
<li>v-for &#x904D;&#x5386;&#x5FC5;&#x987B;&#x4E3A; item &#x6DFB;&#x52A0; key&#xFF0C;&#x4E14;&#x907F;&#x514D;&#x540C;&#x65F6;&#x4F7F;&#x7528; v-if
v-for &#x904D;&#x5386;&#x5FC5;&#x987B;&#x4E3A; item &#x6DFB;&#x52A0; key&#xFF0C;&#x5FAA;&#x73AF;&#x8C03;&#x7528;&#x5B50;&#x7EC4;&#x4EF6;&#x65F6;&#x6DFB;&#x52A0; key&#xFF0C;key &#x53EF;&#x4EE5;&#x552F;&#x4E00;&#x6807;&#x8BC6;&#x4E00;&#x4E2A;&#x5FAA;&#x73AF;&#x4E2A;&#x4F53;&#xFF0C;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x4F8B;&#x5982; item.id &#x4F5C;&#x4E3A; key
&#x907F;&#x514D;&#x540C;&#x65F6;&#x4F7F;&#x7528; v-if&#xFF0C;v-for &#x6BD4; v-if &#x4F18;&#x5148;&#x7EA7;&#x9AD8;&#xFF0C;&#x5982;&#x679C;&#x6BCF;&#x4E00;&#x6B21;&#x90FD;&#x9700;&#x8981;&#x904D;&#x5386;&#x6574;&#x4E2A;&#x6570;&#x7EC4;&#xFF0C;&#x5C06;&#x4F1A;&#x5F71;&#x54CD;&#x901F;&#x5EA6;&#x3002;</li>
</ul>
<p>6&#x3001;Webpack &#x5BF9;&#x56FE;&#x7247;&#x8FDB;&#x884C;&#x538B;&#x7F29;</p>
<p>7&#x3001;&#x907F;&#x514D;&#x5185;&#x5B58;&#x6CC4;&#x6F0F;</p>
<p>8&#x3001;&#x51CF;&#x5C11; ES6 &#x8F6C;&#x4E3A; ES5 &#x7684;&#x5197;&#x4F59;&#x4EE3;&#x7801;</p>
<h5 id="75-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-nexttick&#x77E5;&#x9053;&#x5417;&#x3001;&#x5B9E;&#x73B0;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x662F;&#x5B8F;&#x4EFB;&#x52A1;&#x8FD8;&#x662F;&#x5FAE;&#x4EFB;&#x52A1;&#xFF1F;"><a name="75-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-nexttick&#x77E5;&#x9053;&#x5417;&#x3001;&#x5B9E;&#x73B0;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x662F;&#x5B8F;&#x4EFB;&#x52A1;&#x8FD8;&#x662F;&#x5FAE;&#x4EFB;&#x52A1;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#75-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-nexttick&#x77E5;&#x9053;&#x5417;&#x3001;&#x5B9E;&#x73B0;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x662F;&#x5B8F;&#x4EFB;&#x52A1;&#x8FD8;&#x662F;&#x5FAE;&#x4EFB;&#x52A1;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="75-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-nexttick&#x77E5;&#x9053;&#x5417;&#x3001;&#x5B9E;&#x73B0;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x662F;&#x5B8F;&#x4EFB;&#x52A1;&#x8FD8;&#x662F;&#x5FAE;&#x4EFB;&#x52A1;&#xFF1F;" class="plugin-anchor" href="#75-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-nexttick&#x77E5;&#x9053;&#x5417;&#x3001;&#x5B9E;&#x73B0;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x662F;&#x5B8F;&#x4EFB;&#x52A1;&#x8FD8;&#x662F;&#x5FAE;&#x4EFB;&#x52A1;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>75. &#x2605;&#x2605;&#x2605;&#x2605;&#x2605; nextTick&#x77E5;&#x9053;&#x5417;&#x3001;&#x5B9E;&#x73B0;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x662F;&#x5B8F;&#x4EFB;&#x52A1;&#x8FD8;&#x662F;&#x5FAE;&#x4EFB;&#x52A1;&#xFF1F;</h5>
<p>&#x5FAE;&#x4EFB;&#x52A1;</p>
<p>&#x539F;&#x7406;&#xFF1A;</p>
<p> nextTick&#x65B9;&#x6CD5;&#x4E3B;&#x8981;&#x662F;&#x4F7F;&#x7528;&#x4E86;&#x5B8F;&#x4EFB;&#x52A1;&#x548C;&#x5FAE;&#x4EFB;&#x52A1;&#xFF0C;&#x5B9A;&#x4E49;&#x4E86;&#x4E00;&#x4E2A;&#x5F02;&#x6B65;&#x65B9;&#x6CD5;&#xFF0C;&#x591A;&#x6B21;&#x8C03;&#x7528;nextTick&#x4F1A;&#x5C06;&#x65B9;&#x6CD5;&#x5B58;&#x5165;&#x961F;&#x5217;&#x4E2D;&#xFF0C;&#x901A;&#x8FC7;&#x8FD9;&#x4E2A;&#x5F02;&#x6B65;&#x65B9;&#x6CD5;&#x6E05;&#x7A7A;&#x961F;&#x5217;&#x3002; </p>
<p> &#x4F5C;&#x7528;&#xFF1A;
nextTick&#x7528;&#x4E8E;&#x4E0B;&#x6B21;Dom&#x66F4;&#x65B0;&#x5FAA;&#x73AF;&#x7ED3;&#x675F;&#x4E4B;&#x540E;&#x6267;&#x884C;&#x5EF6;&#x8FDF;&#x56DE;&#x8C03;&#xFF0C;&#x5728;&#x4FEE;&#x6539;&#x6570;&#x636E;&#x4E4B;&#x540E;&#x4F7F;&#x7528;nextTick&#x7528;&#x4E8E;&#x4E0B;&#x6B21;Dom&#x66F4;&#x65B0;&#x5FAA;&#x73AF;&#x7ED3;&#x675F;&#x4E4B;&#x540E;&#x6267;&#x884C;&#x5EF6;&#x8FDF;&#x56DE;&#x8C03;&#xFF0C;&#x5728;&#x4FEE;&#x6539;&#x6570;&#x636E;&#x4E4B;&#x540E;&#x4F7F;&#x7528;nextTick&#x7528;&#x4E8E;&#x4E0B;&#x6B21;Dom&#x66F4;&#x65B0;&#x5FAA;&#x73AF;&#x7ED3;&#x675F;&#x4E4B;&#x540E;&#x6267;&#x884C;&#x5EF6;&#x8FDF;&#x56DE;&#x8C03;&#xFF0C;&#x5728;&#x4FEE;&#x6539;&#x6570;&#x636E;&#x4E4B;&#x540E;&#x4F7F;&#x7528;nextTick,&#x5219;&#x53EF;&#x4EE5;&#x5728;&#x56DE;&#x8C03;&#x4E2D;&#x83B7;&#x53D6;&#x66F4;&#x65B0;&#x540E;&#x7684;DOM&#x3002; </p>
<h5 id="76-&#x2605;&#x2605;&#x2605;-&#x4ECB;&#x7ECD;&#x4E0B;vue&#x5355;&#x9875;&#x9762;&#x548C;&#x591A;&#x9875;&#x9762;&#x533A;&#x522B;"><a name="76-&#x2605;&#x2605;&#x2605;-&#x4ECB;&#x7ECD;&#x4E0B;vue&#x5355;&#x9875;&#x9762;&#x548C;&#x591A;&#x9875;&#x9762;&#x533A;&#x522B;" class="anchor-navigation-ex-anchor" href="#76-&#x2605;&#x2605;&#x2605;-&#x4ECB;&#x7ECD;&#x4E0B;vue&#x5355;&#x9875;&#x9762;&#x548C;&#x591A;&#x9875;&#x9762;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="76-&#x2605;&#x2605;&#x2605;-&#x4ECB;&#x7ECD;&#x4E0B;vue&#x5355;&#x9875;&#x9762;&#x548C;&#x591A;&#x9875;&#x9762;&#x533A;&#x522B;" class="plugin-anchor" href="#76-&#x2605;&#x2605;&#x2605;-&#x4ECB;&#x7ECD;&#x4E0B;vue&#x5355;&#x9875;&#x9762;&#x548C;&#x591A;&#x9875;&#x9762;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a>76. &#x2605;&#x2605;&#x2605; &#x4ECB;&#x7ECD;&#x4E0B;vue&#x5355;&#x9875;&#x9762;&#x548C;&#x591A;&#x9875;&#x9762;&#x533A;&#x522B;</h5>
<p> &#x5355;&#x9875;&#x5E94;&#x7528;
&#x9875;&#x9762;&#x8DF3;&#x8F6C;----&gt;js&#x6E32;&#x67D3;
&#x4F18;&#x70B9;&#xFF1A;&#x9875;&#x9762;&#x5207;&#x6362;&#x5FEB;
&#x7F3A;&#x70B9;&#xFF1A;&#x9996;&#x5C4F;&#x52A0;&#x8F7D;&#x7A0D;&#x6162;&#xFF0C;seo&#x5DEE; </p>
<p> &#x591A;&#x9875;&#x5E94;&#x7528;
&#x9875;&#x9762;&#x8DF3;&#x8F6C;----&gt;&#x8FD4;&#x56DE;html
&#x4F18;&#x70B9;&#xFF1A;&#x9996;&#x5C4F;&#x65F6;&#x95F4;&#x5FEB;&#xFF0C;seo&#x6548;&#x679C;&#x597D;
&#x7F3A;&#x70B9;&#xFF1A;&#x9875;&#x9762;&#x5207;&#x6362;&#x6162; </p>
<h5 id="77-&#x2605;&#x2605;&#x2605;-&#x4ECB;&#x7ECD;&#x4E0B;vue&#x7236;&#x5B50;&#x7EC4;&#x4EF6;&#x751F;&#x547D;&#x5468;&#x671F;&#x7684;&#x6267;&#x884C;&#x987A;&#x5E8F;"><a name="77-&#x2605;&#x2605;&#x2605;-&#x4ECB;&#x7ECD;&#x4E0B;vue&#x7236;&#x5B50;&#x7EC4;&#x4EF6;&#x751F;&#x547D;&#x5468;&#x671F;&#x7684;&#x6267;&#x884C;&#x987A;&#x5E8F;" class="anchor-navigation-ex-anchor" href="#77-&#x2605;&#x2605;&#x2605;-&#x4ECB;&#x7ECD;&#x4E0B;vue&#x7236;&#x5B50;&#x7EC4;&#x4EF6;&#x751F;&#x547D;&#x5468;&#x671F;&#x7684;&#x6267;&#x884C;&#x987A;&#x5E8F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="77-&#x2605;&#x2605;&#x2605;-&#x4ECB;&#x7ECD;&#x4E0B;vue&#x7236;&#x5B50;&#x7EC4;&#x4EF6;&#x751F;&#x547D;&#x5468;&#x671F;&#x7684;&#x6267;&#x884C;&#x987A;&#x5E8F;" class="plugin-anchor" href="#77-&#x2605;&#x2605;&#x2605;-&#x4ECB;&#x7ECD;&#x4E0B;vue&#x7236;&#x5B50;&#x7EC4;&#x4EF6;&#x751F;&#x547D;&#x5468;&#x671F;&#x7684;&#x6267;&#x884C;&#x987A;&#x5E8F;"><i class="fa fa-link" aria-hidden="true"></i></a>77. &#x2605;&#x2605;&#x2605; &#x4ECB;&#x7ECD;&#x4E0B;vue&#x7236;&#x5B50;&#x7EC4;&#x4EF6;&#x751F;&#x547D;&#x5468;&#x671F;&#x7684;&#x6267;&#x884C;&#x987A;&#x5E8F;</h5>
<p><a href="https://blog.csdn.net/weixin_30616969/article/details/94973817" target="_blank">&#x53C2;&#x8003;</a></p>
<h5 id="78-&#x2605;&#x2605;&#x2605;&#x2605;-&#x865A;&#x62DF;-dom-&#x4E3A;&#x4EC0;&#x4E48;&#x4F1A;&#x63D0;&#x9AD8;&#x6027;&#x80FD;&#xFF1F;"><a name="78-&#x2605;&#x2605;&#x2605;&#x2605;-&#x865A;&#x62DF;-dom-&#x4E3A;&#x4EC0;&#x4E48;&#x4F1A;&#x63D0;&#x9AD8;&#x6027;&#x80FD;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#78-&#x2605;&#x2605;&#x2605;&#x2605;-&#x865A;&#x62DF;-dom-&#x4E3A;&#x4EC0;&#x4E48;&#x4F1A;&#x63D0;&#x9AD8;&#x6027;&#x80FD;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="78-&#x2605;&#x2605;&#x2605;&#x2605;-&#x865A;&#x62DF;-dom-&#x4E3A;&#x4EC0;&#x4E48;&#x4F1A;&#x63D0;&#x9AD8;&#x6027;&#x80FD;&#xFF1F;" class="plugin-anchor" href="#78-&#x2605;&#x2605;&#x2605;&#x2605;-&#x865A;&#x62DF;-dom-&#x4E3A;&#x4EC0;&#x4E48;&#x4F1A;&#x63D0;&#x9AD8;&#x6027;&#x80FD;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>78. &#x2605;&#x2605;&#x2605;&#x2605; &#x865A;&#x62DF; dom &#x4E3A;&#x4EC0;&#x4E48;&#x4F1A;&#x63D0;&#x9AD8;&#x6027;&#x80FD;&#xFF1F;</h5>
<p> &#x865A;&#x62DF;DOM&#x5176;&#x5B9E;&#x5C31;&#x662F;&#x4E00;&#x4E2A;JavaScript&#x5BF9;&#x8C61;&#x3002;&#x901A;&#x8FC7;&#x8FD9;&#x4E2A;JavaScript&#x5BF9;&#x8C61;&#x6765;&#x63CF;&#x8FF0;&#x771F;&#x5B9E;DOM&#xFF0C;&#x771F;&#x5B9E;DOM&#x7684;&#x64CD;&#x4F5C;&#xFF0C;&#x4E00;&#x822C;&#x90FD;&#x4F1A;&#x5BF9;&#x67D0;&#x5757;&#x5143;&#x7D20;&#x7684;&#x6574;&#x4F53;&#x91CD;&#x65B0;&#x6E32;&#x67D3;&#xFF0C;&#x91C7;&#x7528;&#x865A;&#x62DF;DOM&#x7684;&#x8BDD;&#xFF0C;&#x5F53;&#x6570;&#x636E;&#x53D8;&#x5316;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x53EA;&#x9700;&#x8981;&#x5C40;&#x90E8;&#x5237;&#x65B0;&#x53D8;&#x5316;&#x7684;&#x4F4D;&#x7F6E;&#x5C31;&#x597D;&#x4E86; ,</p>
<p> &#x865A;&#x62DF;<code>dom</code>&#x76F8;&#x5F53;&#x4E8E;&#x5728;<code>js</code>&#x548C;&#x771F;&#x5B9E;<code>dom</code>&#x4E2D;&#x95F4;&#x52A0;&#x4E86;&#x4E00;&#x4E2A;&#x7F13;&#x5B58;&#xFF0C;&#x5229;&#x7528;<code>dom diff</code>&#x7B97;&#x6CD5;&#x907F;&#x514D;&#x4E86;&#x6CA1;&#x6709;&#x5FC5;&#x8981;&#x7684;<code>dom</code>&#x64CD;&#x4F5C;&#xFF0C;&#x4ECE;&#x800C;&#x63D0;&#x9AD8;&#x6027;&#x80FD; </p>
<p><strong>&#x5177;&#x4F53;&#x5B9E;&#x73B0;&#x6B65;&#x9AA4;&#x5982;&#x4E0B;</strong></p>
<ul>
<li>&#x7528; <code>JavaScript</code> &#x5BF9;&#x8C61;&#x7ED3;&#x6784;&#x8868;&#x793A; <code>DOM</code> &#x6811;&#x7684;&#x7ED3;&#x6784;&#xFF1B;&#x7136;&#x540E;&#x7528;&#x8FD9;&#x4E2A;&#x6811;&#x6784;&#x5EFA;&#x4E00;&#x4E2A;&#x771F;&#x6B63;&#x7684; <code>DOM</code> &#x6811;&#xFF0C;&#x63D2;&#x5230;&#x6587;&#x6863;&#x5F53;&#x4E2D;</li>
<li>&#x5F53;&#x72B6;&#x6001;&#x53D8;&#x66F4;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x91CD;&#x65B0;&#x6784;&#x9020;&#x4E00;&#x68F5;&#x65B0;&#x7684;&#x5BF9;&#x8C61;&#x6811;&#x3002;&#x7136;&#x540E;&#x7528;&#x65B0;&#x7684;&#x6811;&#x548C;&#x65E7;&#x7684;&#x6811;&#x8FDB;&#x884C;&#x6BD4;&#x8F83;&#xFF0C;&#x8BB0;&#x5F55;&#x4E24;&#x68F5;&#x6811;&#x5DEE;&#x5F02;</li>
<li>&#x628A;2&#x6240;&#x8BB0;&#x5F55;&#x7684;&#x5DEE;&#x5F02;&#x5E94;&#x7528;&#x5230;&#x6B65;&#x9AA4;1&#x6240;&#x6784;&#x5EFA;&#x7684;&#x771F;&#x6B63;&#x7684;<code>DOM</code>&#x6811;&#x4E0A;&#xFF0C;&#x89C6;&#x56FE;&#x5C31;&#x66F4;&#x65B0;</li>
</ul>
<h5 id="79-&#x2605;&#x2605;&#x2605;&#x2605;-vue-&#x7684;-computed-&#x7684;&#x539F;&#x7406;"><a name="79-&#x2605;&#x2605;&#x2605;&#x2605;-vue-&#x7684;-computed-&#x7684;&#x539F;&#x7406;" class="anchor-navigation-ex-anchor" href="#79-&#x2605;&#x2605;&#x2605;&#x2605;-vue-&#x7684;-computed-&#x7684;&#x539F;&#x7406;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="79-&#x2605;&#x2605;&#x2605;&#x2605;-vue-&#x7684;-computed-&#x7684;&#x539F;&#x7406;" class="plugin-anchor" href="#79-&#x2605;&#x2605;&#x2605;&#x2605;-vue-&#x7684;-computed-&#x7684;&#x539F;&#x7406;"><i class="fa fa-link" aria-hidden="true"></i></a>79. &#x2605;&#x2605;&#x2605;&#x2605; Vue &#x7684; computed &#x7684;&#x539F;&#x7406;</h5>
<p><a href="https://segmentfault.com/a/1190000010408657" target="_blank">&#x53C2;&#x8003;</a></p>
<h5 id="80-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;key&#x7684;&#x4F5C;&#x7528;&#xFF1F;&#x4E0D;&#x52A0;&#x4F1A;&#x600E;&#x4E48;&#x6837;&#xFF1F;"><a name="80-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;key&#x7684;&#x4F5C;&#x7528;&#xFF1F;&#x4E0D;&#x52A0;&#x4F1A;&#x600E;&#x4E48;&#x6837;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#80-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;key&#x7684;&#x4F5C;&#x7528;&#xFF1F;&#x4E0D;&#x52A0;&#x4F1A;&#x600E;&#x4E48;&#x6837;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="80-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;key&#x7684;&#x4F5C;&#x7528;&#xFF1F;&#x4E0D;&#x52A0;&#x4F1A;&#x600E;&#x4E48;&#x6837;&#xFF1F;" class="plugin-anchor" href="#80-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;key&#x7684;&#x4F5C;&#x7528;&#xFF1F;&#x4E0D;&#x52A0;&#x4F1A;&#x600E;&#x4E48;&#x6837;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>80. &#x2605;&#x2605;&#x2605; Vue&#x4E2D;key&#x7684;&#x4F5C;&#x7528;&#xFF1F;&#x4E0D;&#x52A0;&#x4F1A;&#x600E;&#x4E48;&#x6837;&#xFF1F;</h5>
<p>vue&#x4E2D;&#x5217;&#x8868;&#x5FAA;&#x73AF;&#x9700;&#x52A0;:key=&quot;&#x552F;&#x4E00;&#x6807;&#x8BC6;&quot; &#x552F;&#x4E00;&#x6807;&#x8BC6;&#x53EF;&#x4EE5;&#x662F;item&#x91CC;&#x9762;id index&#x7B49;&#xFF0C;&#x56E0;&#x4E3A;vue&#x7EC4;&#x4EF6;&#x9AD8;&#x5EA6;&#x590D;&#x7528;&#x589E;&#x52A0;Key&#x53EF;&#x4EE5;&#x6807;&#x8BC6;&#x7EC4;&#x4EF6;&#x7684;&#x552F;&#x4E00;&#x6027;&#xFF0C;&#x4E3A;&#x4E86;&#x66F4;&#x597D;&#x5730;&#x533A;&#x522B;&#x5404;&#x4E2A;&#x7EC4;&#x4EF6; key&#x7684;&#x4F5C;&#x7528;&#x4E3B;&#x8981;&#x662F;&#x4E3A;&#x4E86;&#x9AD8;&#x6548;&#x7684;&#x66F4;&#x65B0;&#x865A;&#x62DF;DOM</p>
<h5 id="81-&#x2605;&#x2605;&#x2605;-vue&#x7684;&#x5E38;&#x7528;&#x4FEE;&#x9970;&#x7B26;"><a name="81-&#x2605;&#x2605;&#x2605;-vue&#x7684;&#x5E38;&#x7528;&#x4FEE;&#x9970;&#x7B26;" class="anchor-navigation-ex-anchor" href="#81-&#x2605;&#x2605;&#x2605;-vue&#x7684;&#x5E38;&#x7528;&#x4FEE;&#x9970;&#x7B26;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="81-&#x2605;&#x2605;&#x2605;-vue&#x7684;&#x5E38;&#x7528;&#x4FEE;&#x9970;&#x7B26;" class="plugin-anchor" href="#81-&#x2605;&#x2605;&#x2605;-vue&#x7684;&#x5E38;&#x7528;&#x4FEE;&#x9970;&#x7B26;"><i class="fa fa-link" aria-hidden="true"></i></a>81. &#x2605;&#x2605;&#x2605; Vue&#x7684;&#x5E38;&#x7528;&#x4FEE;&#x9970;&#x7B26;</h5>
<p><strong>&#x4E00;&#x3001;v-model&#x4FEE;&#x9970;&#x7B26;</strong></p>
<p>1&#x3001;.lazy&#xFF1A;</p>
<p>&#x8F93;&#x5165;&#x6846;&#x6539;&#x53D8;&#xFF0C;&#x8FD9;&#x4E2A;&#x6570;&#x636E;&#x5C31;&#x4F1A;&#x6539;&#x53D8;&#xFF0C;lazy&#x8FD9;&#x4E2A;&#x4FEE;&#x9970;&#x7B26;&#x4F1A;&#x5728;&#x5149;&#x6807;&#x79BB;&#x5F00;input&#x6846;&#x624D;&#x4F1A;&#x66F4;&#x65B0;&#x6570;&#x636E;&#xFF1A;</p>
<p><img src="https://img2020.cnblogs.com/blog/1472868/202004/1472868-20200422095359145-2129658851.png" alt="img"></p>
<p>2&#x3001;.trim&#xFF1A;</p>
<p>&#x8F93;&#x5165;&#x6846;&#x8FC7;&#x6EE4;&#x9996;&#x5C3E;&#x7684;&#x7A7A;&#x683C;&#xFF1A;</p>
<p><img src="https://img2020.cnblogs.com/blog/1472868/202004/1472868-20200422095421707-831592670.png" alt="img"></p>
<p>3&#x3001;.number&#xFF1A;</p>
<p>&#x5148;&#x8F93;&#x5165;&#x6570;&#x5B57;&#x5C31;&#x4F1A;&#x9650;&#x5236;&#x8F93;&#x5165;&#x53EA;&#x80FD;&#x662F;&#x6570;&#x5B57;&#xFF0C;&#x5148;&#x5B57;&#x7B26;&#x4E32;&#x5C31;&#x76F8;&#x5F53;&#x4E8E;&#x6CA1;&#x6709;&#x52A0;number&#xFF0C;&#x6CE8;&#x610F;&#xFF0C;&#x4E0D;&#x662F;&#x8F93;&#x5165;&#x6846;&#x4E0D;&#x80FD;&#x8F93;&#x5165;&#x5B57;&#x7B26;&#x4E32;&#xFF0C;&#x662F;&#x8FD9;&#x4E2A;&#x6570;&#x636E;&#x662F;&#x6570;&#x5B57;&#xFF1A;<img src="https://img2020.cnblogs.com/blog/1472868/202004/1472868-20200422095441517-895479507.png" alt="img"></p>
<p><strong>&#x4E8C;&#x3001;&#x4E8B;&#x4EF6;&#x4FEE;&#x9970;&#x7B26;</strong></p>
<p>4&#x3001;.stop&#xFF1A;</p>
<p>&#x963B;&#x6B62;&#x4E8B;&#x4EF6;&#x5192;&#x6CE1;&#xFF0C;&#x76F8;&#x5F53;&#x4E8E;&#x8C03;&#x7528;&#x4E86;event.stopPropagation()&#x65B9;&#x6CD5;&#xFF1A;</p>
<p> <img src="https://img2020.cnblogs.com/blog/1472868/202004/1472868-20200422095722262-891576888.png" alt="img"></p>
<p>5&#x3001;.prevent&#xFF1A;</p>
<p>&#x963B;&#x6B62;&#x9ED8;&#x8BA4;&#x884C;&#x4E3A;&#xFF0C;&#x76F8;&#x5F53;&#x4E8E;&#x8C03;&#x7528;&#x4E86;event.preventDefault()&#x65B9;&#x6CD5;&#xFF0C;&#x6BD4;&#x5982;&#x8868;&#x5355;&#x7684;&#x63D0;&#x4EA4;&#x3001;a&#x6807;&#x7B7E;&#x7684;&#x8DF3;&#x8F6C;&#x5C31;&#x662F;&#x9ED8;&#x8BA4;&#x4E8B;&#x4EF6;&#xFF1A;</p>
<p><img src="https://img2020.cnblogs.com/blog/1472868/202004/1472868-20200422095520346-1148774494.png" alt="img"></p>
<p>6&#x3001;.self&#xFF1A;</p>
<p>&#x53EA;&#x6709;&#x5143;&#x7D20;&#x672C;&#x8EAB;&#x89E6;&#x53D1;&#x65F6;&#x624D;&#x89E6;&#x53D1;&#x65B9;&#x6CD5;&#xFF0C;&#x5C31;&#x662F;&#x53EA;&#x6709;&#x70B9;&#x51FB;&#x5143;&#x7D20;&#x672C;&#x8EAB;&#x624D;&#x4F1A;&#x89E6;&#x53D1;&#x3002;&#x6BD4;&#x5982;&#x4E00;&#x4E2A;div&#x91CC;&#x9762;&#x6709;&#x4E2A;&#x6309;&#x94AE;&#xFF0C;div&#x548C;&#x6309;&#x94AE;&#x90FD;&#x6709;&#x4E8B;&#x4EF6;&#xFF0C;&#x6211;&#x4EEC;&#x70B9;&#x51FB;&#x6309;&#x94AE;&#xFF0C;div&#x7ED1;&#x5B9A;&#x7684;&#x65B9;&#x6CD5;&#x4E5F;&#x4F1A;&#x89E6;&#x53D1;&#xFF0C;&#x5982;&#x679C;div&#x7684;click&#x52A0;&#x4E0A;self&#xFF0C;&#x53EA;&#x6709;&#x70B9;&#x51FB;&#x5230;div&#x7684;&#x65F6;&#x5019;&#x624D;&#x4F1A;&#x89E6;&#x53D1;&#xFF0C;&#x53D8;&#x76F8;&#x7684;&#x7B97;&#x662F;&#x963B;&#x6B62;&#x5192;&#x6CE1;&#xFF1A;</p>
<p><img src="https://img2020.cnblogs.com/blog/1472868/202004/1472868-20200422095746426-1272980881.png" alt="img"></p>
<p>7&#x3001;.once&#xFF1A;</p>
<p>&#x4E8B;&#x4EF6;&#x53EA;&#x80FD;&#x7528;&#x4E00;&#x6B21;&#xFF0C;&#x65E0;&#x8BBA;&#x70B9;&#x51FB;&#x51E0;&#x6B21;&#xFF0C;&#x6267;&#x884C;&#x4E00;&#x6B21;&#x4E4B;&#x540E;&#x90FD;&#x4E0D;&#x4F1A;&#x518D;&#x6267;&#x884C;</p>
<p><img src="https://img2020.cnblogs.com/blog/1472868/202004/1472868-20200422095802227-1462269056.png" alt="img"></p>
<p>8&#x3001;.capture&#xFF1A;</p>
<p>&#x4E8B;&#x4EF6;&#x7684;&#x5B8C;&#x6574;&#x673A;&#x5236;&#x662F;&#x6355;&#x83B7;-&#x76EE;&#x6807;-&#x5192;&#x6CE1;&#xFF0C;&#x4E8B;&#x4EF6;&#x89E6;&#x53D1;&#x662F;&#x76EE;&#x6807;&#x5F80;&#x5916;&#x5192;&#x6CE1;</p>
<p>9&#x3001;.sync</p>
<p>&#x5BF9;prop&#x8FDB;&#x884C;&#x53CC;&#x5411;&#x7ED1;&#x5B9A;</p>
<p>10&#x3001;.keyCode&#xFF1A;</p>
<p>&#x76D1;&#x542C;&#x6309;&#x952E;&#x7684;&#x6307;&#x4EE4;&#xFF0C;&#x5177;&#x4F53;&#x53EF;&#x4EE5;&#x67E5;&#x770B;vue&#x7684;&#x952E;&#x7801;&#x5BF9;&#x5E94;&#x8868;</p>
<h5 id="82-&#x2605;&#x2605;&#x2605;-vue&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#x548C;-watch-&#x7684;&#x533A;&#x522B;"><a name="82-&#x2605;&#x2605;&#x2605;-vue&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#x548C;-watch-&#x7684;&#x533A;&#x522B;" class="anchor-navigation-ex-anchor" href="#82-&#x2605;&#x2605;&#x2605;-vue&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#x548C;-watch-&#x7684;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="82-&#x2605;&#x2605;&#x2605;-vue&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#x548C;-watch-&#x7684;&#x533A;&#x522B;" class="plugin-anchor" href="#82-&#x2605;&#x2605;&#x2605;-vue&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#x548C;-watch-&#x7684;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a>82. &#x2605;&#x2605;&#x2605; Vue&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#x548C; Watch &#x7684;&#x533A;&#x522B;</h5>
<h5 id="methods&#xFF08;&#x65B9;&#x6CD5;&#xFF09;&#xFF1A;"><a name="methods&#xFF08;&#x65B9;&#x6CD5;&#xFF09;&#xFF1A;" class="anchor-navigation-ex-anchor" href="#methods&#xFF08;&#x65B9;&#x6CD5;&#xFF09;&#xFF1A;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="methods&#xFF08;&#x65B9;&#x6CD5;&#xFF09;&#xFF1A;" class="plugin-anchor" href="#methods&#xFF08;&#x65B9;&#x6CD5;&#xFF09;&#xFF1A;"><i class="fa fa-link" aria-hidden="true"></i></a>methods&#xFF08;&#x65B9;&#x6CD5;&#xFF09;&#xFF1A;</h5>
<p>&#x53EA;&#x8981;&#x8FDB;&#x884C;&#x8C03;&#x7528;&#x5C31;&#x4F1A;&#x6267;&#x884C;&#xFF0C;&#x4E0D;&#x7BA1;&#x4F9D;&#x8D56;&#x7684;&#x503C;&#x6709;&#x6CA1;&#x6709;&#x6539;&#x53D8;&#x3002;&#x65E0;&#x7F13;&#x5B58;&#x3002;</p>
<h5 id="computed&#xFF08;&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#xFF1A;"><a name="computed&#xFF08;&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#xFF1A;" class="anchor-navigation-ex-anchor" href="#computed&#xFF08;&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#xFF1A;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="computed&#xFF08;&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#xFF1A;" class="plugin-anchor" href="#computed&#xFF08;&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#xFF1A;"><i class="fa fa-link" aria-hidden="true"></i></a>computed&#xFF08;&#x8BA1;&#x7B97;&#x5C5E;&#x6027;)&#xFF1A;</h5>
<p>&#x76D1;&#x542C;&#x5176;&#x6240;&#x6709;&#x4F9D;&#x8D56;&#x7684;&#x53D8;&#x5316;&#xFF0C;&#x5982;&#x679C;&#x6709;&#x53D8;&#x5316;&#x4F1A;&#x6267;&#x884C;&#xFF0C;&#x6CA1;&#x6709;&#x53D8;&#x5316;&#x4E0D;&#x6267;&#x884C;&#x3002;&#x6709;&#x7F13;&#x5B58;&#xFF0C;&#x4E0D;&#x7528;&#x6BCF;&#x6B21;&#x91CD;&#x65B0;&#x7B97;&#x3002;&#x4E0D;&#x652F;&#x6301;&#x5F02;&#x6B65;&#x3002;</p>
<p>&#x8BE6;&#x89E3;&#xFF1A;&#x5728;vue&#x7684; &#x6A21;&#x677F;&#x5185;&#xFF08;<code>{{}}</code>&#xFF09;&#x662F;&#x53EF;&#x4EE5;&#x5199;&#x4E00;&#x4E9B;&#x7B80;&#x5355;&#x7684;js&#x8868;&#x8FBE;&#x5F0F;&#x7684; &#xFF0C;&#x5F88;&#x4FBF;&#x5229;&#x3002;&#x4F46;&#x662F;&#x5982;&#x679C;&#x5728;&#x9875;&#x9762;&#x4E2D;&#x4F7F;&#x7528;&#x5927;&#x91CF;&#x6216;&#x662F;&#x590D;&#x6742;&#x7684;&#x8868;&#x8FBE;&#x5F0F;&#x53BB;&#x5904;&#x7406;&#x6570;&#x636E;&#xFF0C;&#x5BF9;&#x9875;&#x9762;&#x7684;&#x7EF4;&#x62A4;&#x4F1A;&#x6709;&#x5F88;&#x5927;&#x7684;&#x5F71;&#x54CD;&#x3002;&#x8FD9;&#x4E2A;&#x65F6;&#x5019;&#x5C31;&#x9700;&#x8981;&#x7528;&#x5230;computed &#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#x6765;&#x5904;&#x7406;&#x590D;&#x6742;&#x7684;&#x903B;&#x8F91;&#x8FD0;&#x7B97;&#x3002;</p>
<p>1.&#x4F18;&#x70B9;&#xFF1A;</p>
<p> &#x5728;&#x6570;&#x636E;&#x672A;&#x53D1;&#x751F;&#x53D8;&#x5316;&#x65F6;&#xFF0C;&#x4F18;&#x5148;&#x8BFB;&#x53D6;&#x7F13;&#x5B58;&#x3002;computed &#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#x53EA;&#x6709;&#x5728;&#x76F8;&#x5173;&#x7684;&#x6570;&#x636E;&#x53D1;&#x751F;&#x53D8;&#x5316;&#x65F6;&#x624D;&#x4F1A;&#x6539;&#x53D8;&#x8981;&#x8BA1;&#x7B97;&#x7684;&#x5C5E;&#x6027;&#xFF0C;&#x5F53;&#x76F8;&#x5173;&#x6570;&#x636E;&#x6CA1;&#x6709;&#x53D8;&#x5316;&#x662F;&#xFF0C;&#x5B83;&#x4F1A;&#x8BFB;&#x53D6;&#x7F13;&#x5B58;&#x3002;&#x800C;&#x4E0D;&#x5FC5;&#x60F3; motheds&#x65B9;&#x6CD5; &#x548C; watch &#x65B9;&#x6CD5;&#x662F;&#x5426;&#x6BCF;&#x6B21;&#x90FD;&#x53BB;&#x6267;&#x884C;&#x51FD;&#x6570;&#x3002;</p>
<p>2.setter &#x548C; getter&#x65B9;&#x6CD5;&#xFF1A;&#xFF08;&#x6CE8;&#x610F;&#x5728;vue&#x4E2D;&#x4E66;&#x5199;&#x65F6;&#x7528;set &#x548C; get&#xFF09;</p>
<p> setter &#x65B9;&#x6CD5;&#x5728;&#x8BBE;&#x7F6E;&#x503C;&#x662F;&#x89E6;&#x53D1;&#x3002;</p>
<p> getter &#x65B9;&#x6CD5;&#x5728;&#x83B7;&#x53D6;&#x503C;&#x65F6;&#x89E6;&#x53D1;&#x3002;</p>
<h5 id="watch&#xFF08;&#x4FA6;&#x542C;&#x5C5E;&#x6027;&#xFF09;"><a name="watch&#xFF08;&#x4FA6;&#x542C;&#x5C5E;&#x6027;&#xFF09;" class="anchor-navigation-ex-anchor" href="#watch&#xFF08;&#x4FA6;&#x542C;&#x5C5E;&#x6027;&#xFF09;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="watch&#xFF08;&#x4FA6;&#x542C;&#x5C5E;&#x6027;&#xFF09;" class="plugin-anchor" href="#watch&#xFF08;&#x4FA6;&#x542C;&#x5C5E;&#x6027;&#xFF09;"><i class="fa fa-link" aria-hidden="true"></i></a>watch&#xFF08;&#x4FA6;&#x542C;&#x5C5E;&#x6027;&#xFF09;:</h5>
<p>&#x89C2;&#x5BDF;&#x67D0;&#x4E00;&#x4E2A;&#x53D8;&#x91CF;&#xFF0C;&#x53D1;&#x751F;&#x53D8;&#x5316;&#x4F1A;&#x6267;&#x884C;&#x3002;&#x652F;&#x6301;&#x5F02;&#x6B65;&#x3002;Vue &#x5B9E;&#x4F8B;&#x5C06;&#x4F1A;&#x5728;&#x5B9E;&#x4F8B;&#x5316;&#x65F6;&#x8C03;&#x7528; $watch()&#xFF0C;&#x904D;&#x5386; watch &#x5BF9;&#x8C61;&#x7684;&#x6BCF;&#x4E00;&#x4E2A;&#x5C5E;&#x6027;&#x3002;</p>
<p>&#x4E00;&#x4E2A;&#x5BF9;&#x8C61;&#xFF0C;&#x952E;&#x662F;&#x9700;&#x8981;&#x89C2;&#x5BDF;&#x7684;&#x8868;&#x8FBE;&#x5F0F;&#xFF0C;&#x503C;&#x662F;&#x5BF9;&#x5E94;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#x3002;&#x503C;&#x4E5F;&#x53EF;&#x4EE5;&#x662F;&#x65B9;&#x6CD5;&#x540D;&#xFF0C;&#x6216;&#x8005;&#x5305;&#x542B;&#x9009;&#x9879;&#x7684;&#x5BF9;&#x8C61;&#x3002;</p>
<p>&#x5C0F;&#x7ED3;&#xFF1A;</p>
<p>1.&#x4E3B;&#x52A8;&#x8C03;&#x7528;&#x7684;&#x65B9;&#x6CD5;&#x5199;&#x5728;methods&#x91CC;&#xFF0C;&#x4F9D;&#x636E;&#x67D0;&#x4E9B;&#x53D8;&#x91CF;&#x7684;&#x66F4;&#x65B0;&#x8FDB;&#x884C;&#x67D0;&#x79CD;&#x64CD;&#x4F5C;&#x7528;computed&#x6216;&#x8005;watch&#x3002;</p>
<p>2.computed&#x548C;watch&#xFF1A;&#x5982;&#x679C;&#x8981;&#x5F02;&#x6B65;&#xFF0C;&#x53EA;&#x80FD;&#x7528;watch&#x3002;&#x5982;&#x679C;&#x662F;&#x8BA1;&#x7B97;&#x67D0;&#x4E2A;&#x503C;&#x63A8;&#x8350;&#x7528;computed&#xFF0C;&#x6BD4;&#x5982;&#x8D2D;&#x7269;&#x8F66;&#x5168;&#x9009;&#x5355;&#x9009;&#x529F;&#x80FD;&#xFF0C;&#x8D2D;&#x7269;&#x8F66;&#x8BA1;&#x7B97;&#x603B;&#x4EF7;&#x5C0F;&#x8BA1;&#x529F;&#x80FD;&#x3002;</p>
<h5 id="83-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;-v-on-&#x53EF;&#x4EE5;&#x7ED1;&#x5B9A;&#x591A;&#x4E2A;&#x65B9;&#x6CD5;&#x5417;&#xFF1F;"><a name="83-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;-v-on-&#x53EF;&#x4EE5;&#x7ED1;&#x5B9A;&#x591A;&#x4E2A;&#x65B9;&#x6CD5;&#x5417;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#83-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;-v-on-&#x53EF;&#x4EE5;&#x7ED1;&#x5B9A;&#x591A;&#x4E2A;&#x65B9;&#x6CD5;&#x5417;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="83-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;-v-on-&#x53EF;&#x4EE5;&#x7ED1;&#x5B9A;&#x591A;&#x4E2A;&#x65B9;&#x6CD5;&#x5417;&#xFF1F;" class="plugin-anchor" href="#83-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;-v-on-&#x53EF;&#x4EE5;&#x7ED1;&#x5B9A;&#x591A;&#x4E2A;&#x65B9;&#x6CD5;&#x5417;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>83. &#x2605;&#x2605;&#x2605; Vue &#x4E2D; v-on &#x53EF;&#x4EE5;&#x7ED1;&#x5B9A;&#x591A;&#x4E2A;&#x65B9;&#x6CD5;&#x5417;&#xFF1F;</h5>
<pre><code class="lang-js">&lt;p v-on=<span class="hljs-string">&quot;{click:dbClick,mousemove:MouseClick}&quot;</span>&gt;<span class="xml"><span class="hljs-tag">&lt;/<span class="hljs-name">p</span>&gt;</span></span>
</code></pre>
<h5 id="84-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;-template-&#x7684;&#x7F16;&#x8BD1;&#x8FC7;&#x7A0B;"><a name="84-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;-template-&#x7684;&#x7F16;&#x8BD1;&#x8FC7;&#x7A0B;" class="anchor-navigation-ex-anchor" href="#84-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;-template-&#x7684;&#x7F16;&#x8BD1;&#x8FC7;&#x7A0B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="84-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;-template-&#x7684;&#x7F16;&#x8BD1;&#x8FC7;&#x7A0B;" class="plugin-anchor" href="#84-&#x2605;&#x2605;&#x2605;-vue-&#x4E2D;-template-&#x7684;&#x7F16;&#x8BD1;&#x8FC7;&#x7A0B;"><i class="fa fa-link" aria-hidden="true"></i></a>84. &#x2605;&#x2605;&#x2605; Vue &#x4E2D; template &#x7684;&#x7F16;&#x8BD1;&#x8FC7;&#x7A0B;</h5>
<p>vue template&#x6A21;&#x677F;&#x7F16;&#x8BD1;&#x7684;&#x8FC7;&#x7A0B;&#x7ECF;&#x8FC7;parse()&#x751F;&#x6210;ast(&#x62BD;&#x8C61;&#x8BED;&#x6CD5;&#x6811;),optimize&#x5BF9;&#x9759;&#x6001;&#x8282;&#x70B9;&#x4F18;&#x5316;&#xFF0C;generate()&#x751F;&#x6210;render&#x5B57;&#x7B26;&#x4E32;
&#x4E4B;&#x540E;&#x8C03;&#x7528;new Watcher()&#x51FD;&#x6570;&#xFF0C;&#x7528;&#x6765;&#x76D1;&#x542C;&#x6570;&#x636E;&#x7684;&#x53D8;&#x5316;&#xFF0C;render &#x51FD;&#x6570;&#x5C31;&#x662F;&#x6570;&#x636E;&#x76D1;&#x542C;&#x7684;&#x56DE;&#x8C03;&#x6240;&#x8C03;&#x7528;&#x7684;&#xFF0C;&#x5176;&#x7ED3;&#x679C;&#x4FBF;&#x662F;&#x91CD;&#x65B0;&#x751F;&#x6210; vnode&#x3002;
&#x5F53;&#x8FD9;&#x4E2A; render &#x51FD;&#x6570;&#x5B57;&#x7B26;&#x4E32;&#x5728;&#x7B2C;&#x4E00;&#x6B21; mount&#x3001;&#x6216;&#x8005;&#x7ED1;&#x5B9A;&#x7684;&#x6570;&#x636E;&#x66F4;&#x65B0;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x90FD;&#x4F1A;&#x88AB;&#x8C03;&#x7528;&#xFF0C;&#x751F;&#x6210; Vnode&#x3002;
&#x5982;&#x679C;&#x662F;&#x6570;&#x636E;&#x7684;&#x66F4;&#x65B0;&#xFF0C;&#x90A3;&#x4E48; Vnode &#x4F1A;&#x4E0E;&#x6570;&#x636E;&#x6539;&#x53D8;&#x4E4B;&#x524D;&#x7684; Vnode &#x505A; diff&#xFF0C;&#x5BF9;&#x5185;&#x5BB9;&#x505A;&#x6539;&#x52A8;&#x4E4B;&#x540E;&#xFF0C;&#x5C31;&#x4F1A;&#x66F4;&#x65B0;&#x5230; &#x6211;&#x4EEC;&#x771F;&#x6B63;&#x7684; DOM</p>
<p><a href="https://blog.csdn.net/qq_47008195/article/details/109148309" target="_blank">&#x53C2;&#x8003;</a></p>
<h5 id="85-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x4E2D;&#x5B50;&#x7EC4;&#x4EF6;&#x662F;&#x5426;&#x53EF;&#x4EE5;&#x4FEE;&#x6539;props&#xFF0C;&#x5982;&#x679C;&#x60F3;&#x4FEE;&#x6539;&#x7684;&#x8BDD;&#x5982;&#x4F55;&#x4FEE;&#x6539;"><a name="85-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x4E2D;&#x5B50;&#x7EC4;&#x4EF6;&#x662F;&#x5426;&#x53EF;&#x4EE5;&#x4FEE;&#x6539;props&#xFF0C;&#x5982;&#x679C;&#x60F3;&#x4FEE;&#x6539;&#x7684;&#x8BDD;&#x5982;&#x4F55;&#x4FEE;&#x6539;" class="anchor-navigation-ex-anchor" href="#85-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x4E2D;&#x5B50;&#x7EC4;&#x4EF6;&#x662F;&#x5426;&#x53EF;&#x4EE5;&#x4FEE;&#x6539;props&#xFF0C;&#x5982;&#x679C;&#x60F3;&#x4FEE;&#x6539;&#x7684;&#x8BDD;&#x5982;&#x4F55;&#x4FEE;&#x6539;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="85-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x4E2D;&#x5B50;&#x7EC4;&#x4EF6;&#x662F;&#x5426;&#x53EF;&#x4EE5;&#x4FEE;&#x6539;props&#xFF0C;&#x5982;&#x679C;&#x60F3;&#x4FEE;&#x6539;&#x7684;&#x8BDD;&#x5982;&#x4F55;&#x4FEE;&#x6539;" class="plugin-anchor" href="#85-&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x4E2D;&#x5B50;&#x7EC4;&#x4EF6;&#x662F;&#x5426;&#x53EF;&#x4EE5;&#x4FEE;&#x6539;props&#xFF0C;&#x5982;&#x679C;&#x60F3;&#x4FEE;&#x6539;&#x7684;&#x8BDD;&#x5982;&#x4F55;&#x4FEE;&#x6539;"><i class="fa fa-link" aria-hidden="true"></i></a>85. &#x2605;&#x2605;&#x2605;&#x2605; Vue&#x4E2D;&#x5B50;&#x7EC4;&#x4EF6;&#x662F;&#x5426;&#x53EF;&#x4EE5;&#x4FEE;&#x6539;props&#xFF0C;&#x5982;&#x679C;&#x60F3;&#x4FEE;&#x6539;&#x7684;&#x8BDD;&#x5982;&#x4F55;&#x4FEE;&#x6539;</h5>
<h5 id="86-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;-vuerouter-&#x7684;-hash-&#x6A21;&#x5F0F;&#x548C;-history-&#x6A21;&#x5F0F;&#x533A;&#x522B;"><a name="86-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;-vuerouter-&#x7684;-hash-&#x6A21;&#x5F0F;&#x548C;-history-&#x6A21;&#x5F0F;&#x533A;&#x522B;" class="anchor-navigation-ex-anchor" href="#86-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;-vuerouter-&#x7684;-hash-&#x6A21;&#x5F0F;&#x548C;-history-&#x6A21;&#x5F0F;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="86-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;-vuerouter-&#x7684;-hash-&#x6A21;&#x5F0F;&#x548C;-history-&#x6A21;&#x5F0F;&#x533A;&#x522B;" class="plugin-anchor" href="#86-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;-vuerouter-&#x7684;-hash-&#x6A21;&#x5F0F;&#x548C;-history-&#x6A21;&#x5F0F;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a>86. &#x2605;&#x2605;&#x2605; &#x8BF4;&#x4E00;&#x4E0B; VueRouter &#x7684; hash &#x6A21;&#x5F0F;&#x548C; history &#x6A21;&#x5F0F;&#x533A;&#x522B;</h5>
<table>
<thead>
<tr>
<th></th>
<th>hash</th>
<th>history</th>
</tr>
</thead>
<tbody>
<tr>
<td>url&#x663E;&#x793A;</td>
<td>&#x6709;#&#xFF0C;&#x5F88;Low</td>
<td>&#x65E0;#&#xFF0C;&#x597D;&#x770B;</td>
</tr>
<tr>
<td>&#x56DE;&#x8F66;&#x5237;&#x65B0;</td>
<td>&#x53EF;&#x4EE5;&#x52A0;&#x8F7D;&#x5230;hash&#x503C;&#x5BF9;&#x5E94;&#x9875;&#x9762;</td>
<td>&#x4E00;&#x822C;&#x5C31;&#x662F;404&#x6389;&#x4E86;</td>
</tr>
<tr>
<td>&#x652F;&#x6301;&#x7248;&#x672C;</td>
<td>&#x652F;&#x6301;&#x4F4E;&#x7248;&#x672C;&#x6D4F;&#x89C8;&#x5668;&#x548C;IE&#x6D4F;&#x89C8;&#x5668;</td>
<td>HTML5&#x65B0;&#x63A8;&#x51FA;&#x7684;API</td>
</tr>
</tbody>
</table>
<h5 id="87-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;-router-link-&#x548C;&#x4F20;&#x7EDF;-a-&#x94FE;&#x63A5;&#x7684;&#x533A;&#x522B;&#xFF1F;"><a name="87-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;-router-link-&#x548C;&#x4F20;&#x7EDF;-a-&#x94FE;&#x63A5;&#x7684;&#x533A;&#x522B;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#87-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;-router-link-&#x548C;&#x4F20;&#x7EDF;-a-&#x94FE;&#x63A5;&#x7684;&#x533A;&#x522B;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="87-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;-router-link-&#x548C;&#x4F20;&#x7EDF;-a-&#x94FE;&#x63A5;&#x7684;&#x533A;&#x522B;&#xFF1F;" class="plugin-anchor" href="#87-&#x2605;&#x2605;&#x2605;-vue&#x4E2D;-router-link-&#x548C;&#x4F20;&#x7EDF;-a-&#x94FE;&#x63A5;&#x7684;&#x533A;&#x522B;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>87. &#x2605;&#x2605;&#x2605; Vue&#x4E2D; router-link &#x548C;&#x4F20;&#x7EDF; a &#x94FE;&#x63A5;&#x7684;&#x533A;&#x522B;&#xFF1F;</h5>
<p><router-link> &#x7EC4;&#x4EF6;&#x652F;&#x6301;&#x7528;&#x6237;&#x5728;&#x5177;&#x6709;&#x8DEF;&#x7531;&#x529F;&#x80FD;&#x7684;&#x5E94;&#x7528;&#x4E2D; (&#x70B9;&#x51FB;) &#x5BFC;&#x822A;&#x3002; &#x901A;&#x8FC7; to &#x5C5E;&#x6027;&#x6307;&#x5B9A;&#x76EE;&#x6807;&#x5730;&#x5740;&#xFF0C;&#x9ED8;&#x8BA4;&#x6E32;&#x67D3;&#x6210;&#x5E26;&#x6709;&#x6B63;&#x786E;&#x94FE;&#x63A5;&#x7684; <a> &#x6807;&#x7B7E;&#xFF0C;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x914D;&#x7F6E; tag &#x5C5E;&#x6027;&#x751F;&#x6210;&#x522B;&#x7684;&#x6807;&#x7B7E;.&#x3002;
&#x901A;&#x8FC7;router-link&#x8FDB;&#x884C;&#x8DF3;&#x8F6C;&#x4E0D;&#x4F1A;&#x8DF3;&#x8F6C;&#x5230;&#x65B0;&#x7684;&#x9875;&#x9762;&#xFF0C;&#x4E5F;&#x4E0D;&#x4F1A;&#x91CD;&#x65B0;&#x6E32;&#x67D3;&#xFF0C;&#x5B83;&#x4F1A;&#x9009;&#x62E9;&#x8DEF;&#x7531;&#x6240;&#x6307;&#x7684;&#x7EC4;&#x4EF6;&#x8FDB;&#x884C;&#x6E32;&#x67D3;&#xFF0C;&#x907F;&#x514D;&#x4E86;&#x91CD;&#x590D;&#x6E32;&#x67D3;&#x7684;&#x201C;&#x65E0;&#x7528;&#x529F;&#x201D;&#x3002;
&#x603B;&#x7ED3;&#xFF1A;&#x5BF9;&#x6BD4;<a>&#xFF0C;router-link&#x7EC4;&#x4EF6;&#x907F;&#x514D;&#x4E86;&#x4E0D;&#x5FC5;&#x8981;&#x7684;&#x91CD;&#x6E32;&#x67D3;,&#x5B83;&#x53EA;&#x66F4;&#x65B0;&#x53D8;&#x5316;&#x7684;&#x90E8;&#x5206;&#x4ECE;&#x800C;&#x51CF;&#x5C11;DOM&#x6027;&#x80FD;&#x6D88;&#x8017;</a></a></router-link></p>
<h5 id="88-&#x2605;&#x2605;&#x2605;-vue&#x63D2;&#x69FD;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;"><a name="88-&#x2605;&#x2605;&#x2605;-vue&#x63D2;&#x69FD;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#88-&#x2605;&#x2605;&#x2605;-vue&#x63D2;&#x69FD;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="88-&#x2605;&#x2605;&#x2605;-vue&#x63D2;&#x69FD;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;" class="plugin-anchor" href="#88-&#x2605;&#x2605;&#x2605;-vue&#x63D2;&#x69FD;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>88. &#x2605;&#x2605;&#x2605; Vue&#x63D2;&#x69FD;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;&#x600E;&#x4E48;&#x4F7F;&#x7528;&#xFF1F;</h5>
<p>slot&#x7528;&#x4E8E;&#x5C01;&#x88C5;&#x7EC4;&#x4EF6;&#x4E2D;&#xFF0C;&#x5199;&#x5728;&#x5B50;&#x7EC4;&#x4EF6; &#x63A5;&#x6536;&#x7236;&#x7EC4;&#x4EF6;&#x52A8;&#x6001;&#x4F20;&#x9012;&#x5B50;&#x7EC4;&#x4EF6;&#x5185;&#x5BB9;&#x7247;&#x65AD;</p>
<p>slot&#x63D2;&#x69FD;&#x7684;&#x4F7F;&#x7528;&#x65B9;&#x6CD5;&#x5176;&#x5B9E;&#x5C31;&#x662F;&#x7C7B;&#x4F3C;&#x4E8E;&#x4E00;&#x4E2A;&#x5B50;&#x7EC4;&#x4EF6;&#x6216;&#x8005;&#x6807;&#x7B7E;&#x7684;&#x5F15;&#x7528;&#x7684;&#x8FC7;&#x7A0B;&#xFF0C;&#x5728;&#x7236;&#x7EC4;&#x4EF6;&#x91CC;&#x9762;&#x5B9A;&#x4E49;&#x4E00;&#x4E2A;slot&#xFF0C;&#x7ED9;&#x5979;&#x8D77;&#x4E2A;name&#xFF0C;&#x7136;&#x540E;&#x7EC4;&#x4EF6;&#x5F15;&#x5165;&#x5230;&#x5B50;&#x7EC4;&#x4EF6;&#xFF0C;&#x5B50;&#x7EC4;&#x4EF6;&#x91CC;&#x9762;&#x6709;&#x4E2A;&#x5143;&#x7D20;&#x7684;&#x5C5E;&#x6027;slot&#x503C;&#x7B49;&#x4E8E;name&#xFF0C;&#x7136;&#x540E;&#x7236;&#x7EC4;&#x4EF6;&#x91CC;&#x9762;&#x6CA1;&#x6709;&#x503C;&#x7684;&#x65F6;&#x5019;&#x5C31;&#x53EF;&#x4EE5;&#x663E;&#x793A;&#x5B50;&#x7EC4;&#x4EF6;&#x91CC;&#x9762;&#x7684;&#x4FE1;&#x606F;&#x4E86;&#xFF08;&#x5207;&#x8BB0;&#xFF1A;&#x63D2;&#x69FD;slot&#x8981;&#x5199;&#x5728;&#x7236;&#x7EC4;&#x4EF6;&#x91CC;&#x9762;&#xFF01;&#xFF01;&#xFF01;&#xFF09;</p>
<p>vue slot&#x7528;&#x6CD5;1&#xFF1A;</p>
<p>slot&#x4E3B;&#x8981;&#x662F;&#x8BA9;&#x7EC4;&#x4EF6;&#x7684;&#x53EF;&#x6269;&#x5C55;&#x6027;&#x66F4;&#x5F3A;</p>
<p>1.&#x533F;&#x540D;slot&#x4F7F;&#x7528;</p>
<p>//&#x5B9A;&#x4E49;&#x7EC4;&#x4EF6;</p>
<pre><code>//&#x5B9A;&#x4E49;&#x7EC4;&#x4EF6;
&lt;div class=&quot;Component&gt;
    &lt;slot&gt;&lt;/slot&gt;
&lt;/div&gt;
</code></pre><p>//&#x4F7F;&#x7528;&#x65B9;&#x6CD5;</p>
<pre><code>&lt;component&gt;
    &lt;p&gt;slot&#x5185;&#x5BB9;&#xFF0C;&#x53EF;&#x4EE5;&#x653E;&#x4EFB;&#x4F55;&#x6807;&#x7B7E;&lt;/p&gt;
&lt;/component&gt;
</code></pre><p>2.&#x5177;&#x540D;slot&#x4F7F;&#x7528;</p>
<p>//&#x5B9A;&#x4E49;&#x7EC4;&#x4EF6;</p>
<pre><code>&lt;div class=&quot;Component&gt;
    &lt;slot name=&quot;Slot&quot;&gt;&lt;/slot&gt;
&lt;/div&gt;
</code></pre><p>//&#x4F7F;&#x7528;&#x65B9;&#x6CD5;</p>
<pre><code>&lt;component&gt;
    &lt;p slot=&quot;Slot&gt;&#x53EF;&#x4EE5;&#x653E;&#x4EFB;&#x4F55;&#x6807;&#x7B7E;&#xFF0C;&#x4F46;&#x5FC5;&#x987B;&#x52A0;&#x4E0A;slot=&quot;Slot&quot;,&#x4E0D;&#x7136;&#x4F1A;&#x62A5;&#x9519;&lt;/p&gt;
&lt;/component&gt;
</code></pre><p>&#x5982;&#x679C;&#x4E0D;&#x5728;slot&#x91CC;&#x52A0;&#x5165;&#x4EFB;&#x4F55;&#x6807;&#x7B7E;&#xFF0C;slot&#x4EC0;&#x4E48;&#x90FD;&#x4E0D;&#x4F1A;&#x663E;&#x793A;&#x3002;</p>
<h5 id="89-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;vue-router&#x5B88;&#x536B;&#x6709;&#x54EA;&#x4E9B;&#x3002;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x8DEF;&#x7531;&#x61D2;&#x52A0;&#x8F7D;&#xFF1F;"><a name="89-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;vue-router&#x5B88;&#x536B;&#x6709;&#x54EA;&#x4E9B;&#x3002;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x8DEF;&#x7531;&#x61D2;&#x52A0;&#x8F7D;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#89-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;vue-router&#x5B88;&#x536B;&#x6709;&#x54EA;&#x4E9B;&#x3002;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x8DEF;&#x7531;&#x61D2;&#x52A0;&#x8F7D;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="89-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;vue-router&#x5B88;&#x536B;&#x6709;&#x54EA;&#x4E9B;&#x3002;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x8DEF;&#x7531;&#x61D2;&#x52A0;&#x8F7D;&#xFF1F;" class="plugin-anchor" href="#89-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;vue-router&#x5B88;&#x536B;&#x6709;&#x54EA;&#x4E9B;&#x3002;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x8DEF;&#x7531;&#x61D2;&#x52A0;&#x8F7D;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>89. &#x2605;&#x2605;&#x2605; &#x8BF4;&#x4E00;&#x4E0B;Vue-router&#x5B88;&#x536B;&#x6709;&#x54EA;&#x4E9B;&#x3002;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x8DEF;&#x7531;&#x61D2;&#x52A0;&#x8F7D;&#xFF1F;</h5>
<ul>
<li><code>router.beforeEach</code> &#x5168;&#x5C40;&#x524D;&#x7F6E;&#x5B88;&#x536B; &#x8FDB;&#x5165;&#x8DEF;&#x7531;&#x4E4B;&#x524D;</li>
<li><code>router.beforeResolve</code> &#x5168;&#x5C40;&#x89E3;&#x6790;&#x5B88;&#x536B;(2.5.0+) &#x5728;<code>beforeRouteEnter</code>&#x8C03;&#x7528;&#x4E4B;&#x540E;&#x8C03;&#x7528;</li>
<li><code>router.afterEach</code> &#x5168;&#x5C40;&#x540E;&#x7F6E;&#x94A9;&#x5B50; &#x8FDB;&#x5165;&#x8DEF;&#x7531;&#x4E4B;&#x540E;</li>
</ul>
<p>1&#x3001; Vue&#x5F02;&#x6B65;&#x52A0;&#x8F7D;&#x6280;&#x672F; </p>
<pre><code class="lang-js">     <span class="hljs-number">1</span>&#xFF1A;vue-router&#x914D;&#x7F6E;&#x8DEF;&#x7531;&#xFF0C;&#x4F7F;&#x7528;vue&#x7684;&#x5F02;&#x6B65;&#x7EC4;&#x4EF6;&#x6280;&#x672F;&#xFF0C;&#x53EF;&#x4EE5;&#x5B9E;&#x73B0;&#x61D2;&#x52A0;&#x8F7D;&#xFF0C;&#x6B64;&#x65F6;&#x4E00;&#x4E2A;&#x7EC4;&#x4EF6;&#x4F1A;&#x751F;&#x6210;&#x4E00;&#x4E2A;js&#x6587;&#x4EF6;&#x3002;
     <span class="hljs-number">2</span>&#xFF1A;component: resolve =&gt; <span class="hljs-built_in">require</span>([<span class="hljs-string">&apos;&#x653E;&#x5165;&#x9700;&#x8981;&#x52A0;&#x8F7D;&#x7684;&#x8DEF;&#x7531;&#x5730;&#x5740;&apos;</span>], resolve)
</code></pre>
<p>2&#x3001; ES6&#x63A8;&#x8350;&#x65B9;&#x5F0F;imprort ()----&#x63A8;&#x8350;&#x4F7F;&#x7528; </p>
<pre><code class="lang-js"><span class="hljs-keyword">import</span> Vue <span class="hljs-keyword">from</span> <span class="hljs-string">&apos;vue&apos;</span>;
<span class="hljs-keyword">import</span> Router <span class="hljs-keyword">from</span> <span class="hljs-string">&apos;vue-router&apos;</span>;
<span class="hljs-comment">// &#x5B98;&#x7F51;&#x53EF;&#x77E5;&#xFF1A;&#x4E0B;&#x9762;&#x6CA1;&#x6709;&#x6307;&#x5B9A;webpackChunkName&#xFF0C;&#x6BCF;&#x4E2A;&#x7EC4;&#x4EF6;&#x6253;&#x5305;&#x6210;&#x4E00;&#x4E2A;js&#x6587;&#x4EF6;&#x3002;</span>
<span class="hljs-keyword">const</span> Foo = () =&gt; <span class="hljs-keyword">import</span>(<span class="hljs-string">&apos;../components/Foo&apos;</span>)
<span class="hljs-keyword">const</span> Aoo = () =&gt; <span class="hljs-keyword">import</span>(<span class="hljs-string">&apos;../components/Aoo&apos;</span>)
<span class="hljs-comment">// &#x4E0B;&#x9762;2&#x884C;&#x4EE3;&#x7801;&#xFF0C;&#x6307;&#x5B9A;&#x4E86;&#x76F8;&#x540C;&#x7684;webpackChunkName&#xFF0C;&#x4F1A;&#x5408;&#x5E76;&#x6253;&#x5305;&#x6210;&#x4E00;&#x4E2A;js&#x6587;&#x4EF6;&#x3002;</span>
<span class="hljs-comment">// const Foo = () =&gt; import(/* webpackChunkName: &apos;ImportFuncDemo&apos; */ &apos;../components/Foo&apos;)</span>
<span class="hljs-comment">// const Aoo = () =&gt; import(/* webpackChunkName: &apos;ImportFuncDemo&apos; */ &apos;../components/Aoo&apos;)</span>
<span class="hljs-keyword">export</span> <span class="hljs-keyword">default</span> <span class="hljs-keyword">new</span> Router({
    routes: [
        {
            path: <span class="hljs-string">&apos;/Foo&apos;</span>,
            name: <span class="hljs-string">&apos;Foo&apos;</span>,
            component: Foo
        },
        {
            path: <span class="hljs-string">&apos;/Aoo&apos;</span>,
            name: <span class="hljs-string">&apos;Aoo&apos;</span>,
            component: Aoo
        }
    ]
})
</code></pre>
<p>3&#x3001; webpack&#x63D0;&#x4F9B;&#x7684;require.ensure()&#x5B9E;&#x73B0;&#x61D2;&#x52A0;&#x8F7D;</p>
<pre><code class="lang-js"><span class="hljs-number">1</span>&#xFF1A;vue-router&#x914D;&#x7F6E;&#x8DEF;&#x7531;&#xFF0C;&#x4F7F;&#x7528;webpack&#x7684;<span class="hljs-built_in">require</span>.ensure&#x6280;&#x672F;&#xFF0C;&#x4E5F;&#x53EF;&#x4EE5;&#x5B9E;&#x73B0;&#x6309;&#x9700;&#x52A0;&#x8F7D;&#x3002;
<span class="hljs-number">2</span>&#xFF1A;&#x8FD9;&#x79CD;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;&#x591A;&#x4E2A;&#x8DEF;&#x7531;&#x6307;&#x5B9A;&#x76F8;&#x540C;&#x7684;chunkName&#xFF0C;&#x4F1A;&#x5408;&#x5E76;&#x6253;&#x5305;&#x6210;&#x4E00;&#x4E2A;js&#x6587;&#x4EF6;&#x3002;
<span class="hljs-number">3</span>&#xFF1A;<span class="hljs-built_in">require</span>.ensure&#x53EF;&#x5B9E;&#x73B0;&#x6309;&#x9700;&#x52A0;&#x8F7D;&#x8D44;&#x6E90;&#xFF0C;&#x5305;&#x62EC;js,css&#x7B49;&#x3002;&#x4ED6;&#x4F1A;&#x7ED9;&#x91CC;&#x9762;<span class="hljs-built_in">require</span>&#x7684;&#x6587;&#x4EF6;&#x5355;&#x72EC;&#x6253;&#x5305;&#xFF0C;&#x4E0D;&#x4F1A;&#x548C;&#x4E3B;&#x6587;&#x4EF6;&#x6253;&#x5305;&#x5728;&#x4E00;&#x8D77;&#x3002;
<span class="hljs-number">4</span>&#xFF1A;&#x7B2C;&#x4E00;&#x4E2A;&#x53C2;&#x6570;&#x662F;&#x6570;&#x7EC4;&#xFF0C;&#x8868;&#x660E;&#x7B2C;&#x4E8C;&#x4E2A;&#x53C2;&#x6570;&#x91CC;&#x9700;&#x8981;&#x4F9D;&#x8D56;&#x7684;&#x6A21;&#x5757;&#xFF0C;&#x8FD9;&#x4E9B;&#x4F1A;&#x63D0;&#x524D;&#x52A0;&#x8F7D;&#x3002;
<span class="hljs-number">5</span>&#xFF1A;&#x7B2C;&#x4E8C;&#x4E2A;&#x662F;&#x56DE;&#x8C03;&#x51FD;&#x6570;,&#x5728;&#x8FD9;&#x4E2A;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#x91CC;&#x9762;<span class="hljs-built_in">require</span>&#x7684;&#x6587;&#x4EF6;&#x4F1A;&#x88AB;&#x5355;&#x72EC;&#x6253;&#x5305;&#x6210;&#x4E00;&#x4E2A;chunk,&#x4E0D;&#x4F1A;&#x548C;&#x4E3B;&#x6587;&#x4EF6;&#x6253;&#x5305;&#x5728;&#x4E00;&#x8D77;&#xFF0C;&#x8FD9;&#x6837;&#x5C31;&#x751F;&#x6210;&#x4E86;&#x4E24;&#x4E2A;chunk,&#x7B2C;&#x4E00;&#x6B21;&#x52A0;&#x8F7D;&#x65F6;&#x53EA;&#x52A0;&#x8F7D;&#x4E3B;&#x6587;&#x4EF6;&#x3002;
<span class="hljs-number">6</span>&#xFF1A;&#x7B2C;&#x4E09;&#x4E2A;&#x53C2;&#x6570;&#x662F;&#x9519;&#x8BEF;&#x56DE;&#x8C03;&#x3002;
<span class="hljs-number">7</span>&#xFF1A;&#x7B2C;&#x56DB;&#x4E2A;&#x53C2;&#x6570;&#x662F;&#x5355;&#x72EC;&#x6253;&#x5305;&#x7684;chunk&#x7684;&#x6587;&#x4EF6;&#x540D;

<span class="hljs-keyword">import</span> Vue <span class="hljs-keyword">from</span> <span class="hljs-string">&apos;vue&apos;</span>;
<span class="hljs-keyword">import</span> Router <span class="hljs-keyword">from</span> <span class="hljs-string">&apos;vue-router&apos;</span>;
<span class="hljs-keyword">const</span> HelloWorld=resolve=&gt;{
        <span class="hljs-built_in">require</span>.ensure([<span class="hljs-string">&apos;@/components/HelloWorld&apos;</span>],()=&gt;{
            resolve(<span class="hljs-built_in">require</span>(<span class="hljs-string">&apos;@/components/HelloWorld&apos;</span>))
        })
    }
Vue.use(<span class="hljs-string">&apos;Router&apos;</span>)
<span class="hljs-keyword">export</span> <span class="hljs-keyword">default</span> <span class="hljs-keyword">new</span> Router({
    routes:[{
    {path:<span class="hljs-string">&apos;./&apos;</span>,
    name:<span class="hljs-string">&apos;HelloWorld&apos;</span>,
    component:HelloWorld
    }
    }]
})
</code></pre>
<h5 id="90-&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x662F;-vuejs-&#x52A8;&#x6001;&#x7EC4;&#x4EF6;&#x4E0E;&#x5F02;&#x6B65;&#x7EC4;&#x4EF6;&#xFF1F;"><a name="90-&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x662F;-vuejs-&#x52A8;&#x6001;&#x7EC4;&#x4EF6;&#x4E0E;&#x5F02;&#x6B65;&#x7EC4;&#x4EF6;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#90-&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x662F;-vuejs-&#x52A8;&#x6001;&#x7EC4;&#x4EF6;&#x4E0E;&#x5F02;&#x6B65;&#x7EC4;&#x4EF6;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="90-&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x662F;-vuejs-&#x52A8;&#x6001;&#x7EC4;&#x4EF6;&#x4E0E;&#x5F02;&#x6B65;&#x7EC4;&#x4EF6;&#xFF1F;" class="plugin-anchor" href="#90-&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x662F;-vuejs-&#x52A8;&#x6001;&#x7EC4;&#x4EF6;&#x4E0E;&#x5F02;&#x6B65;&#x7EC4;&#x4EF6;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>90. &#x2605;&#x2605;&#x2605; &#x4EC0;&#x4E48;&#x662F; Vue.js &#x52A8;&#x6001;&#x7EC4;&#x4EF6;&#x4E0E;&#x5F02;&#x6B65;&#x7EC4;&#x4EF6;&#xFF1F;</h5>
<h5 id="91-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;vue&#x4E2D;&#x8DEF;&#x7531;&#x8DF3;&#x8F6C;&#x548C;&#x4F20;&#x503C;&#x7684;&#x65B9;&#x5F0F;"><a name="91-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;vue&#x4E2D;&#x8DEF;&#x7531;&#x8DF3;&#x8F6C;&#x548C;&#x4F20;&#x503C;&#x7684;&#x65B9;&#x5F0F;" class="anchor-navigation-ex-anchor" href="#91-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;vue&#x4E2D;&#x8DEF;&#x7531;&#x8DF3;&#x8F6C;&#x548C;&#x4F20;&#x503C;&#x7684;&#x65B9;&#x5F0F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="91-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;vue&#x4E2D;&#x8DEF;&#x7531;&#x8DF3;&#x8F6C;&#x548C;&#x4F20;&#x503C;&#x7684;&#x65B9;&#x5F0F;" class="plugin-anchor" href="#91-&#x2605;&#x2605;&#x2605;-&#x8BF4;&#x4E00;&#x4E0B;vue&#x4E2D;&#x8DEF;&#x7531;&#x8DF3;&#x8F6C;&#x548C;&#x4F20;&#x503C;&#x7684;&#x65B9;&#x5F0F;"><i class="fa fa-link" aria-hidden="true"></i></a>91. &#x2605;&#x2605;&#x2605; &#x8BF4;&#x4E00;&#x4E0B;Vue&#x4E2D;&#x8DEF;&#x7531;&#x8DF3;&#x8F6C;&#x548C;&#x4F20;&#x503C;&#x7684;&#x65B9;&#x5F0F;</h5>
<p>1&#x3001;&#x8DEF;&#x7531;&#x8DF3;&#x8F6C;</p>
<ol>
<li><p>router-link&#x7EC4;&#x4EF6; &#x9ED8;&#x8BA4;&#x4F1A;&#x88AB;&#x6E32;&#x67D3;&#x6210;&#x4E00;&#x4E2A; &#x6807;&#x7B7E;&#xFF0C;&#x8FDB;&#x884C;&#x8DF3;&#x8F6C;&#xFF0C;&#x5728;&#x7EC4;&#x4EF6;&#x4E2D;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;&#x7ED1;&#x5B9A;<code>to</code>&#x5C5E;&#x6027;&#x6765;&#x6307;&#x5B9A;&#x8981;&#x8DF3;&#x8F6C;&#x7684;&#x94FE;&#x63A5;&#xFF1B;<code>tag</code>&#x5C5E;&#x6027;&#x6307;&#x672C;&#x6765;&#x7684;&#x6807;&#x7B7E; </p>
<pre><code class="lang-js">&lt;router-link :to=&quot;/foo&quot;  tag=&quot;h2&quot;&gt;Foo&lt;/router-link&gt;
</code></pre>
</li>
<li><p>$router.push()&#x65B9;&#x6CD5;</p>
</li>
</ol>
<p>2&#x3001;&#x8DEF;&#x7531;&#x4F20;&#x53C2;</p>
<ol>
<li><p>query</p>
<pre><code class="lang-js"><span class="hljs-comment">// &#x65B9;&#x6CD5;&#x4E00;</span>
&lt;template&gt;
    <span class="xml"><span class="hljs-tag">&lt;<span class="hljs-name">router-link</span>
          <span class="hljs-attr">:to</span>=<span class="hljs-string">&quot;{
                  path: &apos;blogDetail&apos;,
                  query: { id: item.id, views: item.views }
                }&quot;</span>
          <span class="hljs-attr">tag</span>=<span class="hljs-string">&quot;h2&quot;</span>
        &gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">router-link</span>&gt;</span>
<span class="hljs-tag">&lt;/<span class="hljs-name">template</span>&gt;</span></span>

<span class="hljs-comment">// &#x65B9;&#x6CD5;&#x4E8C;</span>
<span class="hljs-keyword">this</span>.$router.push({  
  path: <span class="hljs-string">&apos;blogDetail&apos;</span>, 
  query: { 
    id: item.id,
    views: item.views
  }
})
</code></pre>
</li>
<li><p>params</p>
<pre><code class="lang-js">&lt;template&gt;
    <span class="xml"><span class="hljs-tag">&lt;<span class="hljs-name">router-link</span>
          <span class="hljs-attr">:to</span>=<span class="hljs-string">&quot;{
                  name: &apos;blogDetail&apos;,
                  params: { id: item.id, views: item.views }
                }&quot;</span>
          <span class="hljs-attr">tag</span>=<span class="hljs-string">&quot;h2&quot;</span>
        &gt;</span>
    <span class="hljs-tag">&lt;/<span class="hljs-name">router-link</span>&gt;</span>
<span class="hljs-tag">&lt;/<span class="hljs-name">template</span>&gt;</span></span>

<span class="hljs-keyword">this</span>.$router.push({  
  name: <span class="hljs-string">&apos;blogDetail&apos;</span>, 
  params: { 
    id: item.id,
    views: item.views
  }
})
</code></pre>
</li>
</ol>
<h5 id="92-&#x2605;&#x2605;&#x2605;-&#x6700;&#x8FD1;&#x5173;&#x6CE8;&#x4E86;&#x4EC0;&#x4E48;&#x65B0;&#x6280;&#x672F;&#x5417;&#xFF0C;&#x7B80;&#x5355;&#x8BF4;&#x4E0B;&#x4F60;&#x7684;&#x7406;&#x89E3;&#xFF08;vue30&#x4E0E;vue20&#x5BF9;&#x6BD4;"><a name="92-&#x2605;&#x2605;&#x2605;-&#x6700;&#x8FD1;&#x5173;&#x6CE8;&#x4E86;&#x4EC0;&#x4E48;&#x65B0;&#x6280;&#x672F;&#x5417;&#xFF0C;&#x7B80;&#x5355;&#x8BF4;&#x4E0B;&#x4F60;&#x7684;&#x7406;&#x89E3;&#xFF08;vue30&#x4E0E;vue20&#x5BF9;&#x6BD4;" class="anchor-navigation-ex-anchor" href="#92-&#x2605;&#x2605;&#x2605;-&#x6700;&#x8FD1;&#x5173;&#x6CE8;&#x4E86;&#x4EC0;&#x4E48;&#x65B0;&#x6280;&#x672F;&#x5417;&#xFF0C;&#x7B80;&#x5355;&#x8BF4;&#x4E0B;&#x4F60;&#x7684;&#x7406;&#x89E3;&#xFF08;vue30&#x4E0E;vue20&#x5BF9;&#x6BD4;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="92-&#x2605;&#x2605;&#x2605;-&#x6700;&#x8FD1;&#x5173;&#x6CE8;&#x4E86;&#x4EC0;&#x4E48;&#x65B0;&#x6280;&#x672F;&#x5417;&#xFF0C;&#x7B80;&#x5355;&#x8BF4;&#x4E0B;&#x4F60;&#x7684;&#x7406;&#x89E3;&#xFF08;vue30&#x4E0E;vue20&#x5BF9;&#x6BD4;" class="plugin-anchor" href="#92-&#x2605;&#x2605;&#x2605;-&#x6700;&#x8FD1;&#x5173;&#x6CE8;&#x4E86;&#x4EC0;&#x4E48;&#x65B0;&#x6280;&#x672F;&#x5417;&#xFF0C;&#x7B80;&#x5355;&#x8BF4;&#x4E0B;&#x4F60;&#x7684;&#x7406;&#x89E3;&#xFF08;vue30&#x4E0E;vue20&#x5BF9;&#x6BD4;"><i class="fa fa-link" aria-hidden="true"></i></a>92. &#x2605;&#x2605;&#x2605; &#x6700;&#x8FD1;&#x5173;&#x6CE8;&#x4E86;&#x4EC0;&#x4E48;&#x65B0;&#x6280;&#x672F;&#x5417;&#xFF0C;&#x7B80;&#x5355;&#x8BF4;&#x4E0B;&#x4F60;&#x7684;&#x7406;&#x89E3;&#xFF08;Vue3.0&#x4E0E;Vue2.0&#x5BF9;&#x6BD4;)</h5>
<p>&#x53C2;&#x8003;100&#x9898;</p>
<h5 id="93-&#x2605;&#x2605;&#x2605;&#x2605;-vuex&#x5237;&#x65B0;&#x9875;&#x9762;&#x6570;&#x636E;&#x4F1A;&#x4E22;&#x5931;&#x5417;&#xFF1F;&#x548B;&#x89E3;&#x51B3;&#x7684;&#xFF1F;"><a name="93-&#x2605;&#x2605;&#x2605;&#x2605;-vuex&#x5237;&#x65B0;&#x9875;&#x9762;&#x6570;&#x636E;&#x4F1A;&#x4E22;&#x5931;&#x5417;&#xFF1F;&#x548B;&#x89E3;&#x51B3;&#x7684;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#93-&#x2605;&#x2605;&#x2605;&#x2605;-vuex&#x5237;&#x65B0;&#x9875;&#x9762;&#x6570;&#x636E;&#x4F1A;&#x4E22;&#x5931;&#x5417;&#xFF1F;&#x548B;&#x89E3;&#x51B3;&#x7684;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="93-&#x2605;&#x2605;&#x2605;&#x2605;-vuex&#x5237;&#x65B0;&#x9875;&#x9762;&#x6570;&#x636E;&#x4F1A;&#x4E22;&#x5931;&#x5417;&#xFF1F;&#x548B;&#x89E3;&#x51B3;&#x7684;&#xFF1F;" class="plugin-anchor" href="#93-&#x2605;&#x2605;&#x2605;&#x2605;-vuex&#x5237;&#x65B0;&#x9875;&#x9762;&#x6570;&#x636E;&#x4F1A;&#x4E22;&#x5931;&#x5417;&#xFF1F;&#x548B;&#x89E3;&#x51B3;&#x7684;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>93. &#x2605;&#x2605;&#x2605;&#x2605; Vuex&#x5237;&#x65B0;&#x9875;&#x9762;&#x6570;&#x636E;&#x4F1A;&#x4E22;&#x5931;&#x5417;&#xFF1F;&#x548B;&#x89E3;&#x51B3;&#x7684;&#xFF1F;</h5>
<p>1&#x3001;&#x95EE;&#x9898;&#x63CF;&#x8FF0;&#xFF1A;&#x9875;&#x9762;&#x5237;&#x65B0;&#x7684;&#x65F6;&#x5019;vuex&#x91CC;&#x7684;&#x6570;&#x636E;&#x4F1A;&#x91CD;&#x65B0;&#x521D;&#x59CB;&#x5316;&#xFF0C;&#x5BFC;&#x81F4;&#x6570;&#x636E;&#x4E22;&#x5931;&#x3002;&#x56E0;&#x4E3A;vuex&#x91CC;&#x7684;&#x6570;&#x636E;&#x662F;&#x4FDD;&#x5B58;&#x5728;&#x8FD0;&#x884C;&#x5185;&#x5B58;&#x4E2D;&#x7684;&#xFF0C;&#x5F53;&#x9875;&#x9762;&#x5237;&#x65B0;&#x65F6;&#xFF0C;&#x9875;&#x9762;&#x4F1A;&#x91CD;&#x65B0;&#x52A0;&#x8F7D;vue&#x5B9E;&#x4F8B;&#xFF0C;vuex&#x91CC;&#x9762;&#x7684;&#x6570;&#x636E;&#x5C31;&#x4F1A;&#x88AB;&#x91CD;&#x65B0;&#x8D4B;&#x503C;&#x3002; </p>
<p>2&#x3001;&#x89E3;&#x51B3;&#x601D;&#x8DEF;&#xFF1A;</p>
<p>&#x529E;&#x6CD5;&#x4E00;&#xFF1A;&#x5C06;vuex&#x4E2D;&#x7684;&#x6570;&#x636E;&#x76F4;&#x63A5;&#x4FDD;&#x5B58;&#x5230;&#x6D4F;&#x89C8;&#x5668;&#x7F13;&#x5B58;&#x4E2D;&#xFF08;sessionStorage&#x3001;localStorage&#x3001;cookie&#xFF09;
&#x529E;&#x6CD5;&#x4E8C;&#xFF1A;&#x5728;&#x9875;&#x9762;&#x5237;&#x65B0;&#x7684;&#x65F6;&#x5019;&#x518D;&#x6B21;&#x8BF7;&#x6C42;&#x8FDC;&#x7A0B;&#x6570;&#x636E;&#xFF0C;&#x4F7F;&#x4E4B;&#x52A8;&#x6001;&#x66F4;&#x65B0;vuex&#x6570;&#x636E;
&#x529E;&#x6CD5;&#x4E09;&#xFF1A;&#x5728;&#x7236;&#x9875;&#x9762;&#x5411;&#x540E;&#x53F0;&#x8BF7;&#x6C42;&#x8FDC;&#x7A0B;&#x6570;&#x636E;&#xFF0C;&#x5E76;&#x4E14;&#x5728;&#x9875;&#x9762;&#x5237;&#x65B0;&#x524D;&#x5C06;vuex&#x7684;&#x6570;&#x636E;&#x5148;&#x4FDD;&#x5B58;&#x81F3;sessionStorage&#xFF08;&#x4EE5;&#x9632;&#x8BF7;&#x6C42;&#x6570;&#x636E;&#x91CF;&#x8FC7;&#x5927;&#x9875;&#x9762;&#x52A0;&#x8F7D;&#x65F6;&#x62FF;&#x4E0D;&#x5230;&#x8FD4;&#x56DE;&#x7684;&#x6570;&#x636E;&#xFF09;</p>
<p>3&#x3001; &#x89E3;&#x51B3;&#x8FC7;&#x7A0B;&#xFF1A; </p>
<p> 3.1&#x3001;&#x9009;&#x62E9;&#x5408;&#x9002;&#x7684;&#x6D4F;&#x89C8;&#x5668;&#x5B58;&#x50A8; </p>
<p> 3.2&#x3001;&#x89E3;&#x51B3;&#x65B9;&#x6848; </p>
<ol>
<li>&#x7531;&#x4E8E;state&#x91CC;&#x7684;&#x6570;&#x636E;&#x662F;&#x54CD;&#x5E94;&#x5F0F;&#xFF0C;&#x6240;&#x4EE5;sessionStorage&#x5B58;&#x50A8;&#x4E5F;&#x8981;&#x8DDF;&#x968F;&#x53D8;&#x5316;&#xFF0C;&#x800C;&#x4E14;&#x53EA;&#x80FD;&#x901A;&#x8FC7;mutations&#x6765;&#x6539;&#x53D8;state&#x4E2D;&#x7684;&#x503C;&#x3002;
&#x9996;&#x5148;&#x5728;&#x7528;&#x6237;&#x767B;&#x5F55;&#x6210;&#x529F;&#x4E4B;&#x540E;&#xFF0C;&#x7136;&#x540E;&#x628A;&#x7528;&#x6237;&#x4FE1;&#x606F;&#xFF0C;&#x83DC;&#x5355;&#x4FE1;&#x606F;&#x901A;&#x8FC7;actions&#x5206;&#x53D1;&#x4FDD;&#x5B58;&#x81F3;vuex&#x4E2D;&#x3002;&#x7136;&#x540E;&#x5728;&#x83DC;&#x5355;&#x9875;&#x9762;&#x8BA1;&#x7B97;vuex&#x4E2D;state&#x7684;&#x83DC;&#x5355;&#x6570;&#x636E;&#xFF0C;&#x5C06;&#x6570;&#x636E;&#x89E3;&#x6790;&#x7EC4;&#x88C5;&#x6210;&#x524D;&#x7AEF;&#x7EC4;&#x4EF6;&#x6240;&#x9700;&#x7684;&#x683C;&#x5F0F;&#xFF0C;&#x7136;&#x540E;&#x6E32;&#x67D3;&#x7EC4;&#x4EF6;&#xFF0C;&#x751F;&#x6210;&#x83DC;&#x5355;&#x6811;&#x3002;&#x5982;&#x679C;&#x9875;&#x9762;&#x6CA1;&#x6709;&#x5237;&#x65B0;&#xFF0C;&#x5219;&#x4E00;&#x5207;&#x6B63;&#x5E38;&#x3002;</li>
<li>&#x76D1;&#x542C;&#x6D4F;&#x89C8;&#x5668;&#x5237;&#x65B0;&#x524D;&#x4E8B;&#x4EF6;&#xFF0C;&#x5728;&#x6D4F;&#x89C8;&#x5668;&#x5237;&#x65B0;&#x4E4B;&#x524D;&#x5C31;&#x628A;vuex&#x91CC;&#x7684;&#x6570;&#x636E;&#x4FDD;&#x5B58;&#x81F3;sessionStorage&#x4E2D;&#xFF0C;&#x5237;&#x65B0;&#x6210;&#x529F;&#x540E;&#x5982;&#x679C;&#x5F02;&#x6B65;&#x8BF7;&#x6C42;&#x7684;&#x6570;&#x636E;&#x8FD8;&#x6CA1;&#x8FD4;&#x56DE;&#x5219;&#x76F4;&#x63A5;&#x83B7;&#x53D6;sessionStorage&#x91CC;&#x7684;&#x6570;&#x636E;&#xFF0C;&#x5426;&#x5219;&#x83B7;&#x53D6;vuex&#x91CC;&#x7684;&#x6570;&#x636E;&#x3002; </li>
</ol>
<h5 id="94-&#x2605;&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x662F;-vuenexttick&#xFF1F;"><a name="94-&#x2605;&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x662F;-vuenexttick&#xFF1F;" class="anchor-navigation-ex-anchor" href="#94-&#x2605;&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x662F;-vuenexttick&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="94-&#x2605;&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x662F;-vuenexttick&#xFF1F;" class="plugin-anchor" href="#94-&#x2605;&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x662F;-vuenexttick&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>94. &#x2605;&#x2605;&#x2605;&#x2605; &#x4EC0;&#x4E48;&#x662F; Vue.nextTick()&#xFF1F;</h5>
<p>1&#x3001;$nextTick &#x662F;&#x5728;&#x4E0B;&#x6B21;DOM&#x66F4;&#x65B0;&#x5FAA;&#x73AF;&#x7ED3;&#x675F;&#x4E4B;&#x540E;&#x6267;&#x884C;&#x5EF6;&#x8FDF;&#x56DE;&#x8C03;&#x3002;&#x5728;&#x4FEE;&#x6539;&#x6570;&#x636E;&#x4E4B;&#x540E;&#x7ACB;&#x5373;&#x4F7F;&#x7528;&#x8FD9;&#x4E2A;&#x65B9;&#x6CD5;&#xFF0C;&#x83B7;&#x53D6;&#x66F4;&#x65B0;&#x540E;&#x7684;DOM&#xFF0C;&#x610F;&#x601D;&#x662F; &#x7B49;&#x4F60;dom&#x52A0;&#x8F7D;&#x5B8C;&#x6BD5;&#x4EE5;&#x540E;&#x518D;&#x53BB;&#x8C03;&#x7528;nextTick()&#x91CC;&#x9762;&#x7684;&#x6570;&#x636E;&#x5185;&#x5BB9; </p>
<h5 id="95-&#x2605;&#x2605;&#x2605;-v-if-&#x548C;-v-show&#x7684;&#x533A;&#x522B;"><a name="95-&#x2605;&#x2605;&#x2605;-v-if-&#x548C;-v-show&#x7684;&#x533A;&#x522B;" class="anchor-navigation-ex-anchor" href="#95-&#x2605;&#x2605;&#x2605;-v-if-&#x548C;-v-show&#x7684;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="95-&#x2605;&#x2605;&#x2605;-v-if-&#x548C;-v-show&#x7684;&#x533A;&#x522B;" class="plugin-anchor" href="#95-&#x2605;&#x2605;&#x2605;-v-if-&#x548C;-v-show&#x7684;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a>95. &#x2605;&#x2605;&#x2605; v-if &#x548C; v-show&#x7684;&#x533A;&#x522B;</h5>
<p>1&#x3001;&#x624B;&#x6BB5;&#xFF1A;v-if&#x662F;&#x52A8;&#x6001;&#x7684;&#x5411;DOM&#x6811;&#x6DFB;&#x52A0;&#x6216;&#x8005;&#x5220;&#x9664;DOM&#x5143;&#x7D20;&#xFF1B;v-show&#x662F;&#x901A;&#x8FC7;&#x8BBE;&#x7F6E;DOM&#x5143;&#x7D20;&#x7684;display&#x6837;&#x5F0F;&#x5C5E;&#x6027;&#x63A7;&#x5236;&#x663E;&#x793A;&#x548C;&#x9690;&#x85CF;&#x3002;</p>
<p>2&#x3001;&#x7F16;&#x8BD1;&#x8FC7;&#x7A0B;&#xFF1A;v-if&#x5207;&#x6362;&#x6709;&#x4E00;&#x4E2A;&#x5C40;&#x90E8;&#x7F16;&#x8BD1;/&#x5378;&#x8F7D;&#x7684;&#x8FC7;&#x7A0B;&#xFF0C; &#x5207;&#x6362;&#x8FC7;&#x7A0B;&#x4E2D;&#x5408;&#x9002;&#x5730;&#x9500;&#x6BC1;&#x548C;&#x91CD;&#x5EFA;&#x5185;&#x90E8;&#x7684;&#x4E8B;&#x4EF6;&#x76D1;&#x542C;&#x548C;&#x5B50;&#x7EC4;&#x4EF6;&#xFF1B;v-show&#x53EA;&#x662F;&#x7B80;&#x5355;&#x7684;&#x57FA;&#x4E8E;css&#x5207;&#x6362;&#x3002;</p>
<p>3&#x3001;&#x7F16;&#x8BD1;&#x6761;&#x4EF6;&#xFF1A;v-if&#x662F;&#x60F0;&#x6027;&#x7684;&#xFF0C;&#x5982;&#x679C;&#x521D;&#x59CB;&#x6761;&#x4EF6;&#x4E3A;&#x5047;&#xFF0C;&#x5219;&#x4EC0;&#x4E48;&#x4E5F;&#x4E0D;&#x505A;&#xFF1B;&#x53EA;&#x6709;&#x5728;&#x6761;&#x4EF6;&#x7B2C;&#x4E00;&#x6B21;&#x53D8;&#x4E3A;&#x771F;&#x65F6;&#x624D;&#x5F00;&#x59CB;&#x5C40;&#x90E8;&#x7F16;&#x8BD1;&#xFF08;&#x7F16;&#x8BD1;&#x88AB;&#x7F13;&#x5B58;&#xFF1F;&#x7F16;&#x8BD1;&#x88AB;&#x7F13;&#x5B58;&#x540E;&#xFF0C;&#x7136;&#x540E;&#x518D;&#x5207;&#x6362;&#x7684;&#x65F6;&#x5019;&#x8FDB;&#x884C;&#x5C40;&#x90E8;&#x5378;&#x8F7D;); v-show&#x662F;&#x5728;&#x4EFB;&#x4F55;&#x6761;&#x4EF6;&#x4E0B;&#xFF08;&#x9996;&#x6B21;&#x6761;&#x4EF6;&#x662F;&#x5426;&#x4E3A;&#x771F;&#xFF09;&#x90FD;&#x88AB;&#x7F16;&#x8BD1;&#xFF0C;&#x7136;&#x540E;&#x88AB;&#x7F13;&#x5B58;&#xFF0C;&#x800C;&#x4E14;DOM&#x5143;&#x7D20;&#x4FDD;&#x7559;</p>
<p>4&#x3001;&#x6027;&#x80FD;&#x6D88;&#x8017;&#xFF1A;v-if&#x6709;&#x66F4;&#x9AD8;&#x7684;&#x5207;&#x6362;&#x6D88;&#x8017;&#xFF1B;v-show&#x6709;&#x66F4;&#x9AD8;&#x7684;&#x521D;&#x59CB;&#x6E32;&#x67D3;&#x6D88;&#x8017;
      &#x4F7F;&#x7528;&#x573A;&#x666F;&#xFF1A;v-if&#x9002;&#x5408;&#x8FD0;&#x8425;&#x6761;&#x4EF6;&#x4E0D;&#x5927;&#x53EF;&#x80FD;&#x6539;&#x53D8;&#xFF1B;v-show&#x9002;&#x5408;&#x9891;&#x7E41;&#x5207;&#x6362;</p>
<p>6&#x3001;&#x76F8;&#x540C;&#x70B9;&#xFF1A; v-show &#x90FD;&#x53EF;&#x4EE5;&#x52A8;&#x6001;&#x63A7;&#x5236;&#x7740;dom&#x5143;&#x7D20;&#x7684;&#x663E;&#x793A;&#x9690;&#x85CF;
      &#x4E0D;&#x540C;&#x70B9;&#xFF1A; v-if &#x7684;&#x663E;&#x793A;&#x9690;&#x85CF;&#x662F;&#x5C06;DOM&#x5143;&#x7D20;&#x6574;&#x4E2A;&#x6DFB;&#x52A0;&#x6216;&#x5220;&#x9664;&#xFF0C;v-show &#x7684;&#x663E;&#x793A;&#x9690;&#x85CF;&#x662F;&#x4E3A;DOM&#x5143;&#x7D20;&#x6DFB;</p>
<p>7&#x3001;&#x52A0;css&#x7684;&#x6837;&#x5F0F;display&#xFF0C;&#x8BBE;&#x7F6E;none&#x6216;&#x8005;&#x662F;block&#xFF0C;DOM&#x5143;&#x7D20;&#x662F;&#x8FD8;&#x5B58;&#x5728;&#x7684;</p>
<p>8&#x3001;&#x5728;&#x6E32;&#x67D3;&#x591A;&#x4E2A;&#x5143;&#x7D20;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x53EF;&#x4EE5;&#x628A;&#x4E00;&#x4E2A; &#x5143;&#x7D20;&#x4F5C;&#x4E3A;&#x5305;&#x88C5;&#x5143;&#x7D20;&#xFF0C;&#x5E76;&#x4F7F;&#x7528;v-if &#x8FDB;&#x884C;&#x6761;&#x4EF6;&#x5224;&#x65AD;&#xFF0C;&#x6700;&#x7EC8;&#x7684;&#x6E32;&#x67D3;&#x4E0D;&#x4F1A;&#x5305;&#x542B;&#x8FD9;&#x4E2A;&#x5143;&#x7D20;&#xFF0C;v-show&#x662F;&#x4E0D;&#x652F;&#x6301; &#x8BED;&#x6CD5;</p>
<h5 id="96-&#x2605;&#x2605;&#x2605;-&#x7B80;&#x8FF0;vue&#x6BCF;&#x4E2A;&#x751F;&#x547D;&#x5468;&#x671F;&#x5177;&#x4F53;&#x9002;&#x5408;&#x54EA;&#x4E9B;&#x573A;&#x666F;"><a name="96-&#x2605;&#x2605;&#x2605;-&#x7B80;&#x8FF0;vue&#x6BCF;&#x4E2A;&#x751F;&#x547D;&#x5468;&#x671F;&#x5177;&#x4F53;&#x9002;&#x5408;&#x54EA;&#x4E9B;&#x573A;&#x666F;" class="anchor-navigation-ex-anchor" href="#96-&#x2605;&#x2605;&#x2605;-&#x7B80;&#x8FF0;vue&#x6BCF;&#x4E2A;&#x751F;&#x547D;&#x5468;&#x671F;&#x5177;&#x4F53;&#x9002;&#x5408;&#x54EA;&#x4E9B;&#x573A;&#x666F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="96-&#x2605;&#x2605;&#x2605;-&#x7B80;&#x8FF0;vue&#x6BCF;&#x4E2A;&#x751F;&#x547D;&#x5468;&#x671F;&#x5177;&#x4F53;&#x9002;&#x5408;&#x54EA;&#x4E9B;&#x573A;&#x666F;" class="plugin-anchor" href="#96-&#x2605;&#x2605;&#x2605;-&#x7B80;&#x8FF0;vue&#x6BCF;&#x4E2A;&#x751F;&#x547D;&#x5468;&#x671F;&#x5177;&#x4F53;&#x9002;&#x5408;&#x54EA;&#x4E9B;&#x573A;&#x666F;"><i class="fa fa-link" aria-hidden="true"></i></a>96. &#x2605;&#x2605;&#x2605; &#x7B80;&#x8FF0;Vue&#x6BCF;&#x4E2A;&#x751F;&#x547D;&#x5468;&#x671F;&#x5177;&#x4F53;&#x9002;&#x5408;&#x54EA;&#x4E9B;&#x573A;&#x666F;</h5>
<table>
<thead>
<tr>
<th><strong>&#x751F;&#x547D;&#x5468;&#x671F;</strong></th>
<th><strong>&#x53D1;&#x751F;&#x4E86;&#x4EC0;&#x4E48;</strong></th>
</tr>
</thead>
<tbody>
<tr>
<td>beforeCreate</td>
<td>&#x521D;&#x59CB;&#x5316;&#x754C;&#x9762;&#x524D; : &#x5728;&#x5F53;&#x524D;&#x9636;&#x6BB5;data&#x3001;methods&#x3001;computed&#x4EE5;&#x53CA;watch&#x4E0A;&#x7684;&#x6570;&#x636E;&#x548C;&#x65B9;&#x6CD5;&#x90FD;&#x4E0D;&#x80FD;&#x88AB;&#x8BBF;&#x95EE;&#xFF0C;&#x90FD;&#x8FD8;&#x6CA1;&#x6709;&#x5B8C;&#x6210;&#x521D;&#x59CB;&#x5316;&#x3002;</td>
</tr>
<tr>
<td>created</td>
<td>&#x521D;&#x59CB;&#x5316;&#x754C;&#x9762;&#x540E; : &#x5728;&#x5B9E;&#x4F8B;&#x521B;&#x5EFA;&#x5B8C;&#x6210;&#x540E;&#x53D1;&#x751F;&#xFF0C;&#x5F53;&#x524D;&#x9636;&#x6BB5;&#x5DF2;&#x7ECF;&#x5B8C;&#x6210;&#x4E86;&#x6570;&#x636E;&#x89C2;&#x6D4B;&#xFF0C;&#x4E5F;&#x5C31;&#x662F;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x6570;&#x636E;&#xFF0C;&#x66F4;&#x6539;&#x6570;&#x636E;&#xFF0C;&#x5728;&#x8FD9;&#x91CC;&#x66F4;&#x6539;&#x6570;&#x636E;&#x4E0D;&#x4F1A;&#x89E6;&#x53D1;updated&#x51FD;&#x6570;,&#x4E5F;&#x5C31;&#x662F;&#x4E0D;&#x4F1A;&#x66F4;&#x65B0;&#x89C6;&#x56FE;&#x3002;&#x5B9E;&#x4F8B;&#x7684;data&#x6570;&#x636E;&#x548C;methods&#x65B9;&#x6CD5;&#x90FD;&#x5DF2;&#x7ECF;&#x88AB;&#x521D;&#x59CB;&#x5316;&#x5B8C;&#x6BD5;&#x4E86;&#xFF0C;&#x53EF;&#x4EE5;&#x6B63;&#x5E38;&#x8BBF;&#x95EE;</td>
</tr>
<tr>
<td>beforeMount</td>
<td>&#x6302;&#x8F7D;&#x524D; &#xFF1A;&#x5B8C;&#x6210;&#x6A21;&#x677F;&#x7F16;&#x8BD1;&#xFF0C;&#x865A;&#x62DF;Dom&#x5DF2;&#x7ECF;&#x521B;&#x5EFA;&#x5B8C;&#x6210;&#xFF0C;&#x5373;&#x5C06;&#x5F00;&#x59CB;&#x6E32;&#x67D3;&#x3002;&#x5728;&#x6B64;&#x65F6;&#x4E5F;&#x53EF;&#x4EE5;&#x5BF9;&#x6570;&#x636E;&#x8FDB;&#x884C;&#x66F4;&#x6539;&#xFF0C;&#x4E0D;&#x4F1A;&#x89E6;&#x53D1;updated&#x3002;&#x6570;&#x636E;&#x8FD8;&#x6CA1;&#x6709;&#x66F4;&#x65B0;&#x5230;&#x9875;&#x9762;&#x4E0A;&#x53BB;&#x3002;&#x5F53;&#x7F16;&#x8BD1;&#x5B8C;&#x6210;&#x4E4B;&#x540E;&#xFF0C;&#x53EA;&#x662F;&#x5728;&#x5185;&#x5B58;&#x4E2D;&#x5DF2;&#x7ECF;&#x6709;&#x4E86;&#x7F16;&#x8BD1;&#x597D;&#x7684;&#x9875;&#x9762;&#xFF0C;&#x4F46;&#x5E76;&#x672A;&#x6E32;&#x67D3;&#x3002;</td>
</tr>
<tr>
<td>mounted</td>
<td>&#x6302;&#x8F7D;&#x5B8C;&#x6210; &#xFF1A; &#x5C06;&#x7F16;&#x8BD1;&#x597D;&#x7684;&#x6A21;&#x677F;&#x6302;&#x8F7D;&#x5230;&#x9875;&#x9762; (&#x865A;&#x62DF;DOM&#x6302;&#x8F7D;) &#xFF0C;&#x53EF;&#x4EE5;&#x5728;&#x8FD9;&#x8FDB;&#x884C;&#x5F02;&#x6B65;&#x8BF7;&#x6C42;&#x4EE5;&#x53CA;DOM&#x8282;&#x70B9;&#x7684;&#x8BBF;&#x95EE;&#xFF0C;&#x5728;vue&#x7528;$ref&#x64CD;&#x4F5C;</td>
</tr>
<tr>
<td>beforeUpdate</td>
<td>&#x66F4;&#x65B0;&#x6570;&#x636E;&#x524D; &#xFF1A; &#x7EC4;&#x4EF6;&#x6570;&#x636E;&#x66F4;&#x65B0;&#x4E4B;&#x524D;&#x8C03;&#x7528;&#xFF0C;&#x6570;&#x636E;&#x90FD;&#x662F;&#x65B0;&#x7684;,&#x9875;&#x9762;&#x4E0A;&#x6570;&#x636E;&#x90FD;&#x662F;&#x65E7;&#x7684;&#x3002;&#x5C06;&#x8981;&#x6839;&#x636E;&#x6700;&#x65B0;&#x7684;data&#x6570;&#x636E;&#xFF0C;&#x91CD;&#x65B0;&#x89E3;&#x6790;&#x6240;&#x6709;&#x6307;&#x4EE4;&#xFF0C;&#x4ECE;&#x800C;&#x91CD;&#x65B0;&#x6E32;&#x67D3;&#x6D4F;&#x89C8;&#x5668;&#x9875;&#x9762;&#x3002;</td>
</tr>
<tr>
<td>updated</td>
<td>&#x7EC4;&#x4EF6;&#x66F4;&#x65B0;&#x540E; &#xFF1A; render&#x91CD;&#x65B0;&#x6E32;&#x67D3; , &#x6B64;&#x65F6;&#x6570;&#x636E;&#x548C;&#x754C;&#x9762;&#x90FD;&#x662F;&#x65B0;&#x7684; ,&#x8981;&#x6CE8;&#x610F;&#x7684;&#x662F;&#x907F;&#x514D;&#x5728;&#x6B64;&#x671F;&#x95F4;&#x66F4;&#x6539;&#x6570;&#x636E;&#xFF0C;&#x56E0;&#x4E3A;&#x8FD9;&#x53EF;&#x80FD;&#x4F1A;&#x5BFC;&#x81F4;&#x65E0;&#x9650;&#x5FAA;&#x73AF;&#x7684;&#x66F4;&#x65B0;</td>
</tr>
<tr>
<td>beforeDestroy</td>
<td>&#x7EC4;&#x4EF6;&#x5378;&#x8F7D;&#x524D; : &#x5B9E;&#x4F8B;&#x9500;&#x6BC1;&#x4E4B;&#x524D;&#xFF0C;&#x5728;&#x5F53;&#x524D;&#x9636;&#x6BB5;&#x5B9E;&#x4F8B;&#x5B8C;&#x5168;&#x53EF;&#x4EE5;&#x88AB;&#x4F7F;&#x7528;&#xFF0C;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x5728;&#x8FD9;&#x65F6;&#x8FDB;&#x884C;&#x5584;&#x540E;&#x6536;&#x5C3E;&#x5DE5;&#x4F5C;&#xFF0C;&#x6BD4;&#x5982;&#x6E05;&#x9664;&#x8BA1;&#x65F6;&#x5668;</td>
</tr>
<tr>
<td>destroyed</td>
<td>&#x7EC4;&#x4EF6;&#x5378;&#x8F7D;&#x540E; &#xFF1A; &#x7EC4;&#x4EF6;&#x5DF2;&#x88AB;&#x62C6;&#x89E3;&#xFF0C;&#x6570;&#x636E;&#x7ED1;&#x5B9A;&#x88AB;&#x5378;&#x9664;&#xFF0C;&#x76D1;&#x542C;&#x88AB;&#x79FB;&#x51FA;&#xFF0C;&#x5B50;&#x5B9E;&#x4F8B;&#x4E5F;&#x7EDF;&#x7EDF;&#x88AB;&#x9500;&#x6BC1;&#x3002;</td>
</tr>
<tr>
<td>activited</td>
<td>keep-alive &#x4E13;&#x5C5E; , &#x7EC4;&#x4EF6;&#x88AB;&#x6FC0;&#x6D3B;&#x65F6;&#x8C03;&#x7528;</td>
</tr>
<tr>
<td>deactivated</td>
<td>keep-alive &#x4E13;&#x5C5E; , &#x7EC4;&#x4EF6;&#x88AB;&#x9500;&#x6BC1;&#x65F6;&#x8C03;&#x7528;</td>
</tr>
</tbody>
</table>
<h5 id="97-&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x662F;v-model&#xFF1F;&#x5B83;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;"><a name="97-&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x662F;v-model&#xFF1F;&#x5B83;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#97-&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x662F;v-model&#xFF1F;&#x5B83;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="97-&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x662F;v-model&#xFF1F;&#x5B83;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;" class="plugin-anchor" href="#97-&#x2605;&#x2605;&#x2605;-&#x4EC0;&#x4E48;&#x662F;v-model&#xFF1F;&#x5B83;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>97. &#x2605;&#x2605;&#x2605; &#x4EC0;&#x4E48;&#x662F;v-model&#xFF1F;&#x5B83;&#x7684;&#x539F;&#x7406;&#x662F;&#x4EC0;&#x4E48;&#xFF1F;</h5>
<p>1&#x3001;v-model&#x672C;&#x8D28;&#x4E0A;&#x662F;&#x4E00;&#x4E2A;&#x8BED;&#x6CD5;&#x7CD6;&#xFF0C;&#x53EF;&#x4EE5;&#x770B;&#x6210;&#x662F;value + input &#x65B9;&#x6CD5;&#x7684;&#x8BED;&#x6CD5;&#x7CD6;&#x3002;&#x53EF;&#x4EE5;&#x901A;&#x8FC7;model&#x7684;prop&#x5C5E;&#x6027;&#x548C;event&#x4E8B;&#x4EF6;&#x6765;&#x8FDB;&#x884C;&#x81EA;&#x5B9A;&#x4E49;&#x3002;</p>
<p>2&#x3001;v-model&#x662F;vue&#x7684;&#x53CC;&#x5411;&#x7ED1;&#x5B9A;&#x7684;&#x6307;&#x4EE4;&#xFF0C;&#x80FD;&#x5C06;&#x9875;&#x9762;&#x4E0A;&#x63A7;&#x4EF6;&#x8F93;&#x5165;&#x7684;&#x503C;&#x540C;&#x6B65;&#x66F4;&#x65B0;&#x5230;&#x76F8;&#x5173;&#x7ED1;&#x5B9A;&#x7684;data&#x5C5E;&#x6027;&#xFF0C; &#x4E5F;&#x4F1A;&#x5728;&#x66F4;&#x65B0;<code>data</code>&#x7ED1;&#x5B9A;&#x5C5E;&#x6027;&#x65F6;&#x5019;&#xFF0C;&#x66F4;&#x65B0;&#x9875;&#x9762;&#x4E0A;&#x8F93;&#x5165;&#x63A7;&#x4EF6;&#x7684;&#x503C;&#x3002; </p>
<h5 id="98-&#x2605;&#x2605;&#x2605;-&#x7B80;&#x5355;&#x8BF4;&#x4E00;&#x4E0B;-&#x5FAE;&#x4FE1;&#x5C0F;&#x7A0B;&#x5E8F;-&#x4E0E;-vue-&#x7684;&#x533A;&#x522B;"><a name="98-&#x2605;&#x2605;&#x2605;-&#x7B80;&#x5355;&#x8BF4;&#x4E00;&#x4E0B;-&#x5FAE;&#x4FE1;&#x5C0F;&#x7A0B;&#x5E8F;-&#x4E0E;-vue-&#x7684;&#x533A;&#x522B;" class="anchor-navigation-ex-anchor" href="#98-&#x2605;&#x2605;&#x2605;-&#x7B80;&#x5355;&#x8BF4;&#x4E00;&#x4E0B;-&#x5FAE;&#x4FE1;&#x5C0F;&#x7A0B;&#x5E8F;-&#x4E0E;-vue-&#x7684;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="98-&#x2605;&#x2605;&#x2605;-&#x7B80;&#x5355;&#x8BF4;&#x4E00;&#x4E0B;-&#x5FAE;&#x4FE1;&#x5C0F;&#x7A0B;&#x5E8F;-&#x4E0E;-vue-&#x7684;&#x533A;&#x522B;" class="plugin-anchor" href="#98-&#x2605;&#x2605;&#x2605;-&#x7B80;&#x5355;&#x8BF4;&#x4E00;&#x4E0B;-&#x5FAE;&#x4FE1;&#x5C0F;&#x7A0B;&#x5E8F;-&#x4E0E;-vue-&#x7684;&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a>98. &#x2605;&#x2605;&#x2605; &#x7B80;&#x5355;&#x8BF4;&#x4E00;&#x4E0B; &#x5FAE;&#x4FE1;&#x5C0F;&#x7A0B;&#x5E8F; &#x4E0E; Vue &#x7684;&#x533A;&#x522B;</h5>
<p>1&#x3001;&#x751F;&#x547D;&#x5468;&#x671F;&#xFF1A; </p>
<p><code>&#x5C0F;&#x7A0B;&#x5E8F;</code>&#x7684;&#x94A9;&#x5B50;&#x51FD;&#x6570;&#x8981;&#x7B80;&#x5355;&#x5F97;&#x591A; &#x3002; <code>vue</code>&#x7684;&#x94A9;&#x5B50;&#x51FD;&#x6570;&#x5728;&#x8DF3;&#x8F6C;&#x65B0;&#x9875;&#x9762;&#x65F6;&#xFF0C;&#x94A9;&#x5B50;&#x51FD;&#x6570;&#x90FD;&#x4F1A;&#x89E6;&#x53D1;&#xFF0C;&#x4F46;&#x662F;<code>&#x5C0F;&#x7A0B;&#x5E8F;</code>&#x7684;&#x94A9;&#x5B50;&#x51FD;&#x6570;&#xFF0C;&#x9875;&#x9762;&#x4E0D;&#x540C;&#x7684;&#x8DF3;&#x8F6C;&#x65B9;&#x5F0F;&#xFF0C;&#x89E6;&#x53D1;&#x7684;&#x94A9;&#x5B50;&#x5E76;&#x4E0D;&#x4E00;&#x6837;&#x3002;</p>
<p> &#x5728;&#x9875;&#x9762;&#x52A0;&#x8F7D;&#x8BF7;&#x6C42;&#x6570;&#x636E;&#x65F6;&#xFF0C;&#x4E24;&#x8005;&#x94A9;&#x5B50;&#x7684;&#x4F7F;&#x7528;&#x6709;&#x4E9B;&#x7C7B;&#x4F3C;&#xFF0C;<code>vue</code>&#x4E00;&#x822C;&#x4F1A;&#x5728;<code>created</code>&#x6216;&#x8005;<code>mounted</code>&#x4E2D;&#x8BF7;&#x6C42;&#x6570;&#x636E;&#xFF0C;&#x800C;&#x5728;<code>&#x5C0F;&#x7A0B;&#x5E8F;</code>&#xFF0C;&#x4F1A;&#x5728;<code>onLoad</code>&#x6216;&#x8005;<code>onShow</code>&#x4E2D;&#x8BF7;&#x6C42;&#x6570;&#x636E;&#x3002; </p>
<p>2&#x3001;&#x6570;&#x636E;&#x7ED1;&#x5B9A;&#xFF1A;</p>
<p> vue&#x52A8;&#x6001;&#x7ED1;&#x5B9A;&#x4E00;&#x4E2A;&#x53D8;&#x91CF;&#x7684;&#x503C;&#x4E3A;&#x5143;&#x7D20;&#x7684;&#x67D0;&#x4E2A;&#x5C5E;&#x6027;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x4F1A;&#x5728;&#x53D8;&#x91CF;&#x524D;&#x9762;&#x52A0;&#x4E0A;&#x5192;&#x53F7;&#xFF1A; </p>
<pre><code class="lang-js">&lt;img :src=<span class="hljs-string">&quot;imgSrc&quot;</span>/&gt;
</code></pre>
<p>&#x5C0F;&#x7A0B;&#x5E8F; &#x7ED1;&#x5B9A;&#x67D0;&#x4E2A;&#x53D8;&#x91CF;&#x7684;&#x503C;&#x4E3A;&#x5143;&#x7D20;&#x5C5E;&#x6027;&#x65F6;&#xFF0C;&#x4F1A;&#x7528;&#x4E24;&#x4E2A;&#x5927;&#x62EC;&#x53F7;&#x62EC;&#x8D77;&#x6765;&#xFF0C;&#x5982;&#x679C;&#x4E0D;&#x52A0;&#x62EC;&#x53F7;&#xFF0C;&#x4E3A;&#x88AB;&#x8BA4;&#x4E3A;&#x662F;&#x5B57;&#x7B26;&#x4E32; </p>
<pre><code class="lang-js">&lt;image src=<span class="hljs-string">&quot;{{imgSrc}}&quot;</span>&gt;<span class="xml"><span class="hljs-tag">&lt;/<span class="hljs-name">image</span>&gt;</span></span>
</code></pre>
<p>3&#x3001;&#x5217;&#x8868;&#x5FAA;&#x73AF;</p>
<p>4&#x3001;&#x663E;&#x793A;&#x4E0E;&#x9690;&#x85CF;&#x5143;&#x7D20;</p>
<p><code>vue</code>&#x4E2D;&#xFF0C;&#x4F7F;&#x7528;<code>v-if</code> &#x548C;<code>v-show</code>&#x63A7;&#x5236;&#x5143;&#x7D20;&#x7684;&#x663E;&#x793A;&#x548C;&#x9690;&#x85CF;</p>
<p><code>&#x5C0F;&#x7A0B;&#x5E8F;</code>&#x4E2D;&#xFF0C;&#x4F7F;&#x7528;<code>wx-if</code>&#x548C;<code>hidden</code>&#x63A7;&#x5236;&#x5143;&#x7D20;&#x7684;&#x663E;&#x793A;&#x548C;&#x9690;&#x85CF;</p>
<p>5&#x3001;&#x4E8B;&#x4EF6;&#x5904;&#x7406;</p>
<p> <code>vue</code>&#xFF1A;&#x4F7F;&#x7528;<code>v-on:event</code>&#x7ED1;&#x5B9A;&#x4E8B;&#x4EF6;&#xFF0C;&#x6216;&#x8005;&#x4F7F;&#x7528;<code>@event</code>&#x7ED1;&#x5B9A;&#x4E8B;&#x4EF6; </p>
<p> <code>&#x5C0F;&#x7A0B;&#x5E8F;</code>&#x4E2D;&#xFF0C;&#x5168;&#x7528;<code>bindtap(bind+event)</code>&#xFF0C;&#x6216;&#x8005;<code>catchtap(catch+event)</code>&#x7ED1;&#x5B9A;&#x4E8B;&#x4EF6; </p>
<p>6&#x3001;&#x6570;&#x636E;&#x7684;&#x53CC;&#x5411;&#x7ED1;&#x5B9A;</p>
<p> &#x5728;<code>vue</code>&#x4E2D;,&#x53EA;&#x9700;&#x8981;&#x518D;<code>&#x8868;&#x5355;</code>&#x5143;&#x7D20;&#x4E0A;&#x52A0;&#x4E0A;<code>v-model</code>,&#x7136;&#x540E;&#x518D;&#x7ED1;&#x5B9A;<code>data</code>&#x4E2D;&#x5BF9;&#x5E94;&#x7684;&#x4E00;&#x4E2A;&#x503C;&#xFF0C;&#x5F53;&#x8868;&#x5355;&#x5143;&#x7D20;&#x5185;&#x5BB9;&#x53D1;&#x751F;&#x53D8;&#x5316;&#x65F6;&#xFF0C;<code>data</code>&#x4E2D;&#x5BF9;&#x5E94;&#x7684;&#x503C;&#x4E5F;&#x4F1A;&#x76F8;&#x5E94;&#x6539;&#x53D8; &#x3002;</p>
<p> &#x5F53;&#x8868;&#x5355;&#x5185;&#x5BB9;&#x53D1;&#x751F;&#x53D8;&#x5316;&#x65F6;&#xFF0C;&#x4F1A;&#x89E6;&#x53D1;&#x8868;&#x5355;&#x5143;&#x7D20;&#x4E0A;&#x7ED1;&#x5B9A;&#x7684;&#x65B9;&#x6CD5;&#xFF0C;&#x7136;&#x540E;&#x5728;&#x8BE5;&#x65B9;&#x6CD5;&#x4E2D;&#xFF0C;&#x901A;&#x8FC7;<code>this.setData({key:value})</code>&#x6765;&#x5C06;&#x8868;&#x5355;&#x4E0A;&#x7684;&#x503C;&#x8D4B;&#x503C;&#x7ED9;<code>data</code>&#x4E2D;&#x7684;&#x5BF9;&#x5E94;&#x503C; &#x3002;</p>
<p>7&#x3001;&#x7ED1;&#x5B9A;&#x4E8B;&#x4EF6;&#x4F20;&#x53C2;</p>
<p> &#x5728;<code>vue</code>&#x4E2D;&#xFF0C;&#x7ED1;&#x5B9A;&#x4E8B;&#x4EF6;&#x4F20;&#x53C2;&#x633A;&#x7B80;&#x5355;&#xFF0C;&#x53EA;&#x9700;&#x8981;&#x5728;&#x89E6;&#x53D1;&#x4E8B;&#x4EF6;&#x7684;&#x65B9;&#x6CD5;&#x4E2D;&#xFF0C;&#x628A;&#x9700;&#x8981;&#x4F20;&#x9012;&#x7684;&#x6570;&#x636E;&#x4F5C;&#x4E3A;&#x5F62;&#x53C2;&#x4F20;&#x5165;&#x5C31;&#x53EF;&#x4EE5;&#x4E86; </p>
<p> &#x5728;<code>&#x5C0F;&#x7A0B;&#x5E8F;</code>&#x4E2D;&#xFF0C;&#x4E0D;&#x80FD;&#x76F4;&#x63A5;&#x5728;&#x7ED1;&#x5B9A;&#x4E8B;&#x4EF6;&#x7684;&#x65B9;&#x6CD5;&#x4E2D;&#x4F20;&#x5165;&#x53C2;&#x6570;&#xFF0C;&#x9700;&#x8981;&#x5C06;&#x53C2;&#x6570;&#x4F5C;&#x4E3A;&#x5C5E;&#x6027;&#x503C;&#xFF0C;&#x7ED1;&#x5B9A;&#x5230;&#x5143;&#x7D20;&#x4E0A;&#x7684;<code>data-</code>&#x5C5E;&#x6027;&#x4E0A;&#xFF0C;&#x7136;&#x540E;&#x5728;&#x65B9;&#x6CD5;&#x4E2D;&#xFF0C;&#x901A;&#x8FC7;<code>e.currentTarget.dataset.*</code>&#x7684;&#x65B9;&#x5F0F;&#x83B7;&#x53D6; </p>
<p>8&#x3001;&#x7236;&#x5B50;&#x7EC4;&#x4EF6;&#x901A;&#x4FE1;</p>
<p> &#x7236;&#x7EC4;&#x4EF6;&#x5411;&#x5B50;&#x7EC4;&#x4EF6;&#x4F20;&#x9012;&#x6570;&#x636E;&#xFF0C;&#x53EA;&#x9700;&#x8981;&#x5728;&#x5B50;&#x7EC4;&#x4EF6;&#x901A;&#x8FC7;<code>v-bind</code>&#x4F20;&#x5165;&#x4E00;&#x4E2A;&#x503C;&#xFF0C;&#x5728;&#x5B50;&#x7EC4;&#x4EF6;&#x4E2D;&#xFF0C;&#x901A;&#x8FC7;<code>props</code>&#x63A5;&#x6536;&#xFF0C;&#x5373;&#x53EF;&#x5B8C;&#x6210;&#x6570;&#x636E;&#x7684;&#x4F20;&#x9012; </p>
<p> &#x7236;&#x7EC4;&#x4EF6;&#x5411;&#x5B50;&#x7EC4;&#x4EF6;&#x901A;&#x4FE1;&#x548C;<code>vue</code>&#x7C7B;&#x4F3C;&#xFF0C;&#x4F46;&#x662F;<code>&#x5C0F;&#x7A0B;&#x5E8F;</code>&#x6CA1;&#x6709;&#x901A;&#x8FC7;<code>v-bind</code>&#xFF0C;&#x800C;&#x662F;&#x76F4;&#x63A5;&#x5C06;&#x503C;&#x8D4B;&#x503C;&#x7ED9;&#x4E00;&#x4E2A;&#x53D8;&#x91CF;  &#x5728;&#x5B50;&#x7EC4;&#x4EF6;<code>properties</code>&#x4E2D;&#xFF0C;&#x63A5;&#x6536;&#x4F20;&#x9012;&#x7684;&#x503C; </p>
<h5 id="99-&#x2605;&#x2605;&#x2605;-vue&#x7684;&#x7EC4;&#x4EF6;&#x901A;&#x4FE1;"><a name="99-&#x2605;&#x2605;&#x2605;-vue&#x7684;&#x7EC4;&#x4EF6;&#x901A;&#x4FE1;" class="anchor-navigation-ex-anchor" href="#99-&#x2605;&#x2605;&#x2605;-vue&#x7684;&#x7EC4;&#x4EF6;&#x901A;&#x4FE1;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="99-&#x2605;&#x2605;&#x2605;-vue&#x7684;&#x7EC4;&#x4EF6;&#x901A;&#x4FE1;" class="plugin-anchor" href="#99-&#x2605;&#x2605;&#x2605;-vue&#x7684;&#x7EC4;&#x4EF6;&#x901A;&#x4FE1;"><i class="fa fa-link" aria-hidden="true"></i></a>99. &#x2605;&#x2605;&#x2605; Vue&#x7684;&#x7EC4;&#x4EF6;&#x901A;&#x4FE1;</h5>
<p>1&#x3001;props&#x548C;$emit</p>
<p>&#x7236;&#x7EC4;&#x4EF6;&#x5411;&#x5B50;&#x7EC4;&#x4EF6;&#x4F20;&#x9012;&#x6570;&#x636E;&#x662F;&#x901A;&#x8FC7;prop&#x4F20;&#x9012;&#x7684;&#xFF0C;&#x5B50;&#x7EC4;&#x4EF6;&#x4F20;&#x9012;&#x6570;&#x636E;&#x7ED9;&#x7236;&#x7EC4;&#x4EF6;&#x662F;&#x901A;&#x8FC7;$emit&#x89E6;&#x53D1;&#x4E8B;&#x4EF6;</p>
<p>2&#x3001;$attrs&#x548C;$listeners</p>
<p>3&#x3001;&#x4E2D;&#x592E;&#x4E8B;&#x4EF6;&#x603B;&#x7EBF; bus</p>
<p>&#x4E0A;&#x9762;&#x4E24;&#x79CD;&#x65B9;&#x5F0F;&#x5904;&#x7406;&#x7684;&#x90FD;&#x662F;&#x7236;&#x5B50;&#x7EC4;&#x4EF6;&#x4E4B;&#x95F4;&#x7684;&#x6570;&#x636E;&#x4F20;&#x9012;&#xFF0C;&#x800C;&#x5982;&#x679C;&#x4E24;&#x4E2A;&#x7EC4;&#x4EF6;&#x4E0D;&#x662F;&#x7236;&#x5B50;&#x5173;&#x7CFB;&#x5462;&#xFF1F;&#x8FD9;&#x79CD;&#x60C5;&#x51B5;&#x4E0B;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x4E2D;&#x592E;&#x4E8B;&#x4EF6;&#x603B;&#x7EBF;&#x7684;&#x65B9;&#x5F0F;&#x3002;&#x65B0;&#x5EFA;&#x4E00;&#x4E2A;Vue&#x4E8B;&#x4EF6;bus&#x5BF9;&#x8C61;&#xFF0C;&#x7136;&#x540E;&#x901A;&#x8FC7;bus.$emit&#x89E6;&#x53D1;&#x4E8B;&#x4EF6;&#xFF0C;bus.$on&#x76D1;&#x542C;&#x89E6;&#x53D1;&#x7684;&#x4E8B;&#x4EF6;&#x3002; </p>
<p>4&#x3001;provide&#x548C;inject</p>
<p>&#x7236;&#x7EC4;&#x4EF6;&#x4E2D;&#x901A;&#x8FC7;provider&#x6765;&#x63D0;&#x4F9B;&#x53D8;&#x91CF;&#xFF0C;&#x7136;&#x540E;&#x5728;&#x5B50;&#x7EC4;&#x4EF6;&#x4E2D;&#x901A;&#x8FC7;inject&#x6765;&#x6CE8;&#x5165;&#x53D8;&#x91CF;&#x3002;&#x4E0D;&#x8BBA;&#x5B50;&#x7EC4;&#x4EF6;&#x6709;&#x591A;&#x6DF1;&#xFF0C;&#x53EA;&#x8981;&#x8C03;&#x7528;&#x4E86;inject&#x90A3;&#x4E48;&#x5C31;&#x53EF;&#x4EE5;&#x6CE8;&#x5165;provider&#x4E2D;&#x7684;&#x6570;&#x636E;&#x3002;&#x800C;&#x4E0D;&#x662F;&#x5C40;&#x9650;&#x4E8E;&#x53EA;&#x80FD;&#x4ECE;&#x5F53;&#x524D;&#x7236;&#x7EC4;&#x4EF6;&#x7684;prop&#x5C5E;&#x6027;&#x6765;&#x83B7;&#x53D6;&#x6570;&#x636E;&#xFF0C;&#x53EA;&#x8981;&#x5728;&#x7236;&#x7EC4;&#x4EF6;&#x7684;&#x751F;&#x547D;&#x5468;&#x671F;&#x5185;&#xFF0C;&#x5B50;&#x7EC4;&#x4EF6;&#x90FD;&#x53EF;&#x4EE5;&#x8C03;&#x7528;&#x3002;</p>
<p>5&#x3001;v-model</p>
<p>&#x7236;&#x7EC4;&#x4EF6;&#x901A;&#x8FC7;v-model&#x4F20;&#x9012;&#x503C;&#x7ED9;&#x5B50;&#x7EC4;&#x4EF6;&#x65F6;&#xFF0C;&#x4F1A;&#x81EA;&#x52A8;&#x4F20;&#x9012;&#x4E00;&#x4E2A;value&#x7684;prop&#x5C5E;&#x6027;&#xFF0C;&#x5728;&#x5B50;&#x7EC4;&#x4EF6;&#x4E2D;&#x901A;&#x8FC7;this.$emit(&#x2018;input&#x2019;,val)&#x81EA;&#x52A8;&#x4FEE;&#x6539;v-model&#x7ED1;&#x5B9A;&#x7684;&#x503C;  </p>
<p>6&#x3001;$parent&#x548C;$children </p>
<p>7&#x3001;boradcast&#x548C;dispatch</p>
<p>8&#x3001;vuex&#x5904;&#x7406;&#x7EC4;&#x4EF6;&#x4E4B;&#x95F4;&#x7684;&#x6570;&#x636E;&#x4EA4;&#x4E92;
&#x5982;&#x679C;&#x4E1A;&#x52A1;&#x903B;&#x8F91;&#x590D;&#x6742;&#xFF0C;&#x5F88;&#x591A;&#x7EC4;&#x4EF6;&#x4E4B;&#x95F4;&#x9700;&#x8981;&#x540C;&#x65F6;&#x5904;&#x7406;&#x4E00;&#x4E9B;&#x516C;&#x5171;&#x7684;&#x6570;&#x636E;&#xFF0C;&#x8FD9;&#x4E2A;&#x65F6;&#x5019;&#x624D;&#x6709;&#x4E0A;&#x9762;&#x8FD9;&#x4E00;&#x4E9B;&#x65B9;&#x6CD5;&#x53EF;&#x80FD;&#x4E0D;&#x5229;&#x4E8E;&#x9879;&#x76EE;&#x7684;&#x7EF4;&#x62A4;&#xFF0C;vuex&#x7684;&#x505A;&#x6CD5;&#x5C31;&#x662F;&#x5C06;&#x8FD9;&#x4E00;&#x4E9B;&#x516C;&#x5171;&#x7684;&#x6570;&#x636E;&#x62BD;&#x79BB;&#x51FA;&#x6765;&#xFF0C;&#x7136;&#x540E;&#x5176;&#x4ED6;&#x7EC4;&#x4EF6;&#x5C31;&#x53EF;&#x4EE5;&#x5BF9;&#x8FD9;&#x4E2A;&#x516C;&#x5171;&#x6570;&#x636E;&#x8FDB;&#x884C;&#x8BFB;&#x5199;&#x64CD;&#x4F5C;&#xFF0C;&#x8FD9;&#x6837;&#x8FBE;&#x5230;&#x4E86;&#x89E3;&#x8026;&#x7684;&#x76EE;&#x7684;&#x3002; </p>
<p><a href="https://blog.csdn.net/zhoulu001/article/details/79548350" target="_blank">vue&#x4E2D;&#x516B;&#x79CD;&#x901A;&#x4FE1;&#x65B9;&#x5F0F;</a></p>
<h5 id="100-&#x2605;&#x2605;&#x2605;-&#x8C08;&#x8C08;&#x4F60;&#x5BF9;vue30&#x6709;&#x4EC0;&#x4E48;&#x4E86;&#x89E3;&#xFF1F;"><a name="100-&#x2605;&#x2605;&#x2605;-&#x8C08;&#x8C08;&#x4F60;&#x5BF9;vue30&#x6709;&#x4EC0;&#x4E48;&#x4E86;&#x89E3;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#100-&#x2605;&#x2605;&#x2605;-&#x8C08;&#x8C08;&#x4F60;&#x5BF9;vue30&#x6709;&#x4EC0;&#x4E48;&#x4E86;&#x89E3;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="100-&#x2605;&#x2605;&#x2605;-&#x8C08;&#x8C08;&#x4F60;&#x5BF9;vue30&#x6709;&#x4EC0;&#x4E48;&#x4E86;&#x89E3;&#xFF1F;" class="plugin-anchor" href="#100-&#x2605;&#x2605;&#x2605;-&#x8C08;&#x8C08;&#x4F60;&#x5BF9;vue30&#x6709;&#x4EC0;&#x4E48;&#x4E86;&#x89E3;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>100. &#x2605;&#x2605;&#x2605; &#x8C08;&#x8C08;&#x4F60;&#x5BF9;Vue3.0&#x6709;&#x4EC0;&#x4E48;&#x4E86;&#x89E3;&#xFF1F;</h5>
<h5 id="&#x4E00;&#x3001;&#x516D;&#x5927;&#x4EAE;&#x70B9;"><a name="&#x4E00;&#x3001;&#x516D;&#x5927;&#x4EAE;&#x70B9;" class="anchor-navigation-ex-anchor" href="#&#x4E00;&#x3001;&#x516D;&#x5927;&#x4EAE;&#x70B9;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="&#x4E00;&#x3001;&#x516D;&#x5927;&#x4EAE;&#x70B9;" class="plugin-anchor" href="#&#x4E00;&#x3001;&#x516D;&#x5927;&#x4EAE;&#x70B9;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x4E00;&#x3001;&#x516D;&#x5927;&#x4EAE;&#x70B9;</h5>
<ol>
<li>&#x6027;&#x80FD;&#x6BD4;vue2.x&#x5FEB;1.2~2&#x500D;</li>
<li>&#x652F;&#x6301;tree-shaking&#xFF0C;&#x6309;&#x9700;&#x7F16;&#x8BD1;&#xFF0C;&#x4F53;&#x79EF;&#x6BD4;vue2.x&#x66F4;&#x5C0F;</li>
<li>&#x652F;&#x6301;&#x7EC4;&#x5408;API</li>
<li>&#x66F4;&#x597D;&#x7684;&#x652F;&#x6301;TS</li>
<li>&#x66F4;&#x5148;&#x8FDB;&#x7684;&#x7EC4;&#x4EF6;</li>
</ol>
<h5 id="&#x4E8C;&#x3001;&#x6027;&#x80FD;&#x6BD4;vue2x&#x5FEB;122&#x500D;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x7684;&#x5462;"><a name="&#x4E8C;&#x3001;&#x6027;&#x80FD;&#x6BD4;vue2x&#x5FEB;122&#x500D;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x7684;&#x5462;" class="anchor-navigation-ex-anchor" href="#&#x4E8C;&#x3001;&#x6027;&#x80FD;&#x6BD4;vue2x&#x5FEB;122&#x500D;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x7684;&#x5462;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="&#x4E8C;&#x3001;&#x6027;&#x80FD;&#x6BD4;vue2x&#x5FEB;122&#x500D;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x7684;&#x5462;" class="plugin-anchor" href="#&#x4E8C;&#x3001;&#x6027;&#x80FD;&#x6BD4;vue2x&#x5FEB;122&#x500D;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x7684;&#x5462;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x4E8C;&#x3001;&#x6027;&#x80FD;&#x6BD4;vue2.x&#x5FEB;1.2~2&#x500D;&#x5982;&#x4F55;&#x5B9E;&#x73B0;&#x7684;&#x5462;</h5>
<p>1.diff&#x7B97;&#x6CD5;&#x66F4;&#x5FEB;</p>
<p>vue2.0&#x662F;&#x9700;&#x8981;&#x5168;&#x5C40;&#x53BB;&#x6BD4;&#x8F83;&#x6BCF;&#x4E2A;&#x8282;&#x70B9;&#x7684;&#xFF0C;&#x82E5;&#x53D1;&#x73B0;&#x6709;&#x8282;&#x70B9;&#x53D1;&#x751F;&#x53D8;&#x5316;&#x540E;&#xFF0C;&#x5C31;&#x53BB;&#x66F4;&#x65B0;&#x8BE5;&#x8282;&#x70B9;</p>
<p>vue3.0&#x662F;&#x5728;&#x521B;&#x5EFA;&#x865A;&#x62DF;dom&#x4E2D;&#xFF0C;&#x4F1A;&#x6839;&#x636E;DOM&#x7684;&#x7684;&#x5185;&#x5BB9;&#x4F1A;&#x4E0D;&#x4F1A;&#x53D1;&#x751F;&#x5185;&#x5BB9;&#x53D8;&#x5316;&#xFF0C;&#x6DFB;&#x52A0;&#x9759;&#x6001;&#x6807;&#x8BB0;&#xFF0C; &#x8C01;&#x6709;flag&#xFF01;&#x6BD4;&#x8F83;&#x8C01;&#x3002;</p>
<p>2&#x3001;&#x9759;&#x6001;&#x63D0;&#x5347;</p>
<p>vue2&#x4E2D;&#x65E0;&#x8BBA;&#x5143;&#x7D20;&#x662F;&#x5426;&#x53C2;&#x4E0E;&#x66F4;&#x65B0;&#xFF0C;&#x6BCF;&#x6B21;&#x90FD;&#x4F1A;&#x91CD;&#x65B0;&#x521B;&#x5EFA;&#xFF0C;&#x7136;&#x540E;&#x518D;&#x6E32;&#x67D3;
vue3&#x4E2D;&#x5BF9;&#x4E8E;&#x4E0D;&#x53C2;&#x4E0E;&#x66F4;&#x65B0;&#x7684;&#x5143;&#x7D20;&#xFF0C;&#x4F1A;&#x505A;&#x9759;&#x6001;&#x63D0;&#x5347;&#xFF0C;&#x53EA;&#x88AB;&#x521B;&#x5EFA;&#x4E00;&#x6B21;&#xFF0C;&#x5728;&#x6E32;&#x67D3;&#x65F6;&#x76F4;&#x63A5;&#x590D;&#x7528;&#x5373;&#x53EF; </p>
<p>3&#x3001;&#x4E8B;&#x4EF6;&#x4FA6;&#x542C;&#x7F13;&#x5B58;</p>
<p>&#x9ED8;&#x8BA4;&#x60C5;&#x51B5;&#x4E0B;&#xFF0C;onclick&#x4E3A;&#x52A8;&#x6001;&#x7ED1;&#x5B9A;&#xFF0C;&#x6240;&#x4EE5;&#x6BCF;&#x6B21;&#x90FD;&#x4F1A;&#x8FFD;&#x8E2A;&#x5B83;&#x7684;&#x53D8;&#x5316;&#xFF0C;&#x4F46;&#x662F;&#x56E0;&#x4E3A;&#x662F;&#x540C;&#x4E00;&#x51FD;&#x6570;&#xFF0C;&#x6CA1;&#x6709;&#x5FC5;&#x8981;&#x8FFD;&#x8E2A;&#x53D8;&#x5316;&#xFF0C;&#x76F4;&#x63A5;&#x7F13;&#x5B58;&#x590D;&#x7528;&#x5373;&#x53EF;</p>
<p>&#x5728;&#x4E4B;&#x524D;&#x4F1A;&#x6DFB;&#x52A0;&#x9759;&#x6001;&#x6807;&#x8BB0;8 &#x4F1A;&#x628A;&#x70B9;&#x51FB;&#x4E8B;&#x4EF6;&#x5F53;&#x505A;&#x52A8;&#x6001;&#x5C5E;&#x6027; &#x4F1A;&#x8FDB;&#x884C;diff&#x7B97;&#x6CD5;&#x6BD4;&#x8F83;&#xFF0C;
&#x4F46;&#x662F;&#x5728;&#x4E8B;&#x4EF6;&#x76D1;&#x542C;&#x7F13;&#x5B58;&#x4E4B;&#x540E;&#x5C31;&#x6CA1;&#x6709;&#x9759;&#x6001;&#x6807;&#x8BB0;&#x4E86;&#xFF0C;&#x5C31;&#x4F1A;&#x8FDB;&#x884C;&#x7F13;&#x5B58;&#x590D;&#x7528; </p>
<h5 id="&#x4E09;&#x3001;&#x4E3A;&#x4EC0;&#x4E48;vue30&#x4F53;&#x79EF;&#x6BD4;vue2x&#x5C0F;"><a name="&#x4E09;&#x3001;&#x4E3A;&#x4EC0;&#x4E48;vue30&#x4F53;&#x79EF;&#x6BD4;vue2x&#x5C0F;" class="anchor-navigation-ex-anchor" href="#&#x4E09;&#x3001;&#x4E3A;&#x4EC0;&#x4E48;vue30&#x4F53;&#x79EF;&#x6BD4;vue2x&#x5C0F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="&#x4E09;&#x3001;&#x4E3A;&#x4EC0;&#x4E48;vue30&#x4F53;&#x79EF;&#x6BD4;vue2x&#x5C0F;" class="plugin-anchor" href="#&#x4E09;&#x3001;&#x4E3A;&#x4EC0;&#x4E48;vue30&#x4F53;&#x79EF;&#x6BD4;vue2x&#x5C0F;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x4E09;&#x3001;&#x4E3A;&#x4EC0;&#x4E48;vue3.0&#x4F53;&#x79EF;&#x6BD4;vue2.x&#x5C0F;</h5>
<p>&#x5728;vue3.0&#x4E2D;&#x521B;&#x5EFA;vue&#x9879;&#x76EE; &#x9664;&#x4E86;vue-cli&#xFF0C;webpack&#x5916;&#x8FD8;&#x6709; &#x4E00;&#x79CD;&#x521B;&#x5EFA;&#x65B9;&#x6CD5;&#x662F;Vite
Vite&#x662F;&#x4F5C;&#x8005;&#x5F00;&#x53D1;&#x7684;&#x4E00;&#x6B3E;&#x6709;&#x610F;&#x53D6;&#x4EE3;webpack&#x7684;&#x5DE5;&#x5177;&#xFF0C;&#x5176;&#x5B9E;&#x73B0;&#x539F;&#x7406;&#x662F;&#x5229;&#x7528;ES6&#x7684;import&#x4F1A;&#x53D1;&#x9001;&#x8BF7;&#x6C42;&#x53BB;&#x52A0;&#x8F7D;&#x6587;&#x4EF6;&#x7684;&#x7279;&#x6027;&#xFF0C;&#x62E6;&#x622A;&#x8FD9;&#x4E9B;&#x8BF7;&#x6C42;&#xFF0C;&#x505A;&#x4E00;&#x4E9B;&#x9884;&#x7F16;&#x8BD1;&#xFF0C;&#x7701;&#x53BB;webpack&#x5197;&#x957F;&#x7684;&#x6253;&#x5305;&#x65F6;&#x95F4; </p>
<h5 id="&#x56DB;&#x3001;vue30&#x7EC4;&#x5408;api"><a name="&#x56DB;&#x3001;vue30&#x7EC4;&#x5408;api" class="anchor-navigation-ex-anchor" href="#&#x56DB;&#x3001;vue30&#x7EC4;&#x5408;api"><i class="fa fa-link" aria-hidden="true"></i></a><a name="&#x56DB;&#x3001;vue30&#x7EC4;&#x5408;api" class="plugin-anchor" href="#&#x56DB;&#x3001;vue30&#x7EC4;&#x5408;api"><i class="fa fa-link" aria-hidden="true"></i></a>&#x56DB;&#x3001;vue3.0&#x7EC4;&#x5408;API</h5>
<p>3.&#x8BF4;&#x4E00;&#x8BF4;vue3.0&#x7684;&#x7EC4;&#x5408;API&#x8DDF;&#x4E4B;&#x524D;vue2.0&#x5728;&#x5B8C;&#x6210;&#x4E1A;&#x52A1;&#x903B;&#x8F91;&#x4E0A;&#x7684;&#x533A;&#x522B;&#xFF1A;</p>
<p>&#x5728;vue2.0&#x4E2D;&#xFF1A;
&#x4E3B;&#x8981;&#x662F;&#x5F80;data &#x548C;method&#x91CC;&#x9762;&#x6DFB;&#x52A0;&#x5185;&#x5BB9;&#xFF0C;&#x4E00;&#x4E2A;&#x4E1A;&#x52A1;&#x903B;&#x8F91;&#x9700;&#x8981;&#x4EC0;&#x4E48;data&#x548C;method&#x5C31;&#x5F80;&#x91CC;&#x9762;&#x6DFB;&#x52A0;&#xFF0C;&#x800C;&#x7EC4;&#x5408;API&#x5C31;&#x662F; &#x6709;&#x4E00;&#x4E2A;&#x81EA;&#x5DF1;&#x7684;&#x65B9;&#x6CD5;&#xFF0C;&#x91CC;&#x9762;&#x6709;&#x81EA;&#x5DF1;&#x4E13;&#x6CE8;&#x7684;data &#x548C;method&#x3002;</p>
<p>4.&#x518D;&#x8BF4;&#x4E00;&#x4E0B;&#x7EC4;&#x5408;API&#x7684;&#x672C;&#x8D28;&#x662F;&#x4EC0;&#x4E48;&#xFF1A;
&#x9996;&#x5148;composition API&#xFF08;&#x7EC4;&#x5408;API&#xFF09;
&#x548C; Option API&#xFF08;vue2.0&#x4E2D;&#x7684;data&#x548C;method&#xFF09;&#x53EF;&#x4EE5;&#x5171;&#x7528;
composition API&#xFF08;&#x7EC4;&#x5408;API&#xFF09;&#x672C;&#x8D28;&#x5C31;&#x662F;&#x628A;&#x5185;&#x5BB9;&#x6DFB;&#x52A0;&#x5230;Option API&#x4E2D;&#x8FDB;&#x884C;&#x4F7F;&#x7528;</p>
<h5 id="&#x4E94;&#x3001;ref&#x548C;reactive&#x7684;&#x7B80;&#x5355;&#x7406;&#x89E3;"><a name="&#x4E94;&#x3001;ref&#x548C;reactive&#x7684;&#x7B80;&#x5355;&#x7406;&#x89E3;" class="anchor-navigation-ex-anchor" href="#&#x4E94;&#x3001;ref&#x548C;reactive&#x7684;&#x7B80;&#x5355;&#x7406;&#x89E3;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="&#x4E94;&#x3001;ref&#x548C;reactive&#x7684;&#x7B80;&#x5355;&#x7406;&#x89E3;" class="plugin-anchor" href="#&#x4E94;&#x3001;ref&#x548C;reactive&#x7684;&#x7B80;&#x5355;&#x7406;&#x89E3;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x4E94;&#x3001;ref&#x548C;reactive&#x7684;&#x7B80;&#x5355;&#x7406;&#x89E3;</h5>
<p>1.ref&#x548C;reactive&#x90FD;&#x662F;vue3&#x7684;&#x76D1;&#x542C;&#x6570;&#x636E;&#x7684;&#x65B9;&#x6CD5;&#xFF0C;&#x672C;&#x8D28;&#x662F;proxy
2.ref &#x57FA;&#x672C;&#x7C7B;&#x578B;&#x590D;&#x6742;&#x7C7B;&#x578B;&#x90FD;&#x53EF;&#x4EE5;&#x76D1;&#x542C;(&#x6211;&#x4EEC;&#x4E00;&#x822C;&#x7528;ref&#x76D1;&#x542C;&#x57FA;&#x672C;&#x7C7B;&#x578B;)&#xFF0C;reactive&#x53EA;&#x80FD;&#x76D1;&#x542C;&#x5BF9;&#x8C61;&#xFF08;arr&#xFF0C;json&#xFF09;
3.ref&#x5E95;&#x5C42;&#x8FD8;&#x662F;reactive </p>
<h5 id="&#x516D;&#x3001;&#x5BF9;&#x751F;&#x547D;&#x5468;&#x671F;&#x7684;&#x76D1;&#x542C;&#xFF08;ref&#x83B7;&#x53D6;&#x5C5E;&#x6027;&#xFF09;"><a name="&#x516D;&#x3001;&#x5BF9;&#x751F;&#x547D;&#x5468;&#x671F;&#x7684;&#x76D1;&#x542C;&#xFF08;ref&#x83B7;&#x53D6;&#x5C5E;&#x6027;&#xFF09;" class="anchor-navigation-ex-anchor" href="#&#x516D;&#x3001;&#x5BF9;&#x751F;&#x547D;&#x5468;&#x671F;&#x7684;&#x76D1;&#x542C;&#xFF08;ref&#x83B7;&#x53D6;&#x5C5E;&#x6027;&#xFF09;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="&#x516D;&#x3001;&#x5BF9;&#x751F;&#x547D;&#x5468;&#x671F;&#x7684;&#x76D1;&#x542C;&#xFF08;ref&#x83B7;&#x53D6;&#x5C5E;&#x6027;&#xFF09;" class="plugin-anchor" href="#&#x516D;&#x3001;&#x5BF9;&#x751F;&#x547D;&#x5468;&#x671F;&#x7684;&#x76D1;&#x542C;&#xFF08;ref&#x83B7;&#x53D6;&#x5C5E;&#x6027;&#xFF09;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x516D;&#x3001;&#x5BF9;&#x751F;&#x547D;&#x5468;&#x671F;&#x7684;&#x76D1;&#x542C;&#xFF08;ref&#x83B7;&#x53D6;&#x5C5E;&#x6027;&#xFF09;</h5>
<h5 id="&#x4E03;&#x3001;proxy&#x54CD;&#x5E94;&#x5F0F;&#x672C;&#x8D28;"><a name="&#x4E03;&#x3001;proxy&#x54CD;&#x5E94;&#x5F0F;&#x672C;&#x8D28;" class="anchor-navigation-ex-anchor" href="#&#x4E03;&#x3001;proxy&#x54CD;&#x5E94;&#x5F0F;&#x672C;&#x8D28;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="&#x4E03;&#x3001;proxy&#x54CD;&#x5E94;&#x5F0F;&#x672C;&#x8D28;" class="plugin-anchor" href="#&#x4E03;&#x3001;proxy&#x54CD;&#x5E94;&#x5F0F;&#x672C;&#x8D28;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x4E03;&#x3001;proxy&#x54CD;&#x5E94;&#x5F0F;&#x672C;&#x8D28;</h5>
<p><a href="https://blog.csdn.net/qq_25503949/article/details/108711024" target="_blank">vue3.0</a></p>
<h5 id="101-&#x2605;&#x2605;&#x2605;-vue&#x5982;&#x4F55;&#x5728;&#x7528;&#x6237;&#x6CA1;&#x767B;&#x9646;&#x7684;&#x65F6;&#x5019;&#x91CD;&#x5B9A;&#x5411;&#x767B;&#x5F55;&#x754C;&#x9762;&#xFF1F;"><a name="101-&#x2605;&#x2605;&#x2605;-vue&#x5982;&#x4F55;&#x5728;&#x7528;&#x6237;&#x6CA1;&#x767B;&#x9646;&#x7684;&#x65F6;&#x5019;&#x91CD;&#x5B9A;&#x5411;&#x767B;&#x5F55;&#x754C;&#x9762;&#xFF1F;" class="anchor-navigation-ex-anchor" href="#101-&#x2605;&#x2605;&#x2605;-vue&#x5982;&#x4F55;&#x5728;&#x7528;&#x6237;&#x6CA1;&#x767B;&#x9646;&#x7684;&#x65F6;&#x5019;&#x91CD;&#x5B9A;&#x5411;&#x767B;&#x5F55;&#x754C;&#x9762;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="101-&#x2605;&#x2605;&#x2605;-vue&#x5982;&#x4F55;&#x5728;&#x7528;&#x6237;&#x6CA1;&#x767B;&#x9646;&#x7684;&#x65F6;&#x5019;&#x91CD;&#x5B9A;&#x5411;&#x767B;&#x5F55;&#x754C;&#x9762;&#xFF1F;" class="plugin-anchor" href="#101-&#x2605;&#x2605;&#x2605;-vue&#x5982;&#x4F55;&#x5728;&#x7528;&#x6237;&#x6CA1;&#x767B;&#x9646;&#x7684;&#x65F6;&#x5019;&#x91CD;&#x5B9A;&#x5411;&#x767B;&#x5F55;&#x754C;&#x9762;&#xFF1F;"><i class="fa fa-link" aria-hidden="true"></i></a>101. &#x2605;&#x2605;&#x2605; Vue&#x5982;&#x4F55;&#x5728;&#x7528;&#x6237;&#x6CA1;&#x767B;&#x9646;&#x7684;&#x65F6;&#x5019;&#x91CD;&#x5B9A;&#x5411;&#x767B;&#x5F55;&#x754C;&#x9762;&#xFF1F;</h5>
<p>&#x73B0;&#x5728; &#x6211;&#x4EEC;&#x9700;&#x8981;&#x5B9E;&#x73B0;&#x8FD9;&#x6837; &#x4E00;&#x4E2A;&#x529F;&#x80FD;&#xFF0C;&#x767B;&#x5F55;&#x62E6;&#x622A;&#xFF0C;&#x5176;&#x5B9E;&#x5C31;&#x662F; &#x8DEF;&#x7531;&#x62E6;&#x622A;&#xFF0C;&#x9996;&#x5148;&#x5728;&#x5B9A;&#x4E49;&#x8DEF;&#x7531;&#x7684;&#x65F6;&#x5019;&#x5C31;&#x9700;&#x8981;&#x591A;&#x6DFB;&#x52A0;&#x4E00;&#x4E2A;&#x81EA;&#x5B9A;&#x4E49;&#x5B57;&#x6BB5;requireAuth&#xFF0C;&#x7528;&#x4E8E;&#x5224;&#x65AD;&#x8BE5;&#x8DEF;&#x7531;&#x7684;&#x8BBF;&#x95EE;&#x662F;&#x5426;&#x9700;&#x8981;&#x767B;&#x5F55;&#x3002;&#x5982;&#x679C;&#x7528;&#x6237;&#x5DF2;&#x7ECF;&#x767B;&#x5F55;&#xFF0C;&#x5219;&#x987A;&#x5229;&#x8FDB;&#x5165;&#x8DEF;&#x7531;&#xFF0C; &#x5426;&#x5219;&#x5C31;&#x8FDB;&#x5165;&#x767B;&#x5F55;&#x9875;&#x9762;&#x3002;&#x5728;&#x8DEF;&#x7531;&#x7BA1;&#x7406;&#x9875;&#x9762;&#x6DFB;&#x52A0;meta&#x5B57;&#x6BB5;</p>
<pre><code class="lang-js">{
  path:<span class="hljs-string">&apos;/manage&apos;</span>,
  name:<span class="hljs-string">&apos;manage&apos;</span>,
  component:manage,
  meta:{requireAuth:<span class="hljs-literal">true</span>}
}
</code></pre>
<p>&#x5728;&#x5165;&#x53E3;&#x6587;&#x4EF6;&#x4E2D;&#xFF0C;&#x6DFB;&#x52A0;&#x8DEF;&#x7531;&#x5B88;&#x536B;</p>
<ol>
<li>&#x5148;&#x5224;&#x65AD;&#x8BE5;&#x8DEF;&#x7531;&#x662F;&#x5426;&#x9700;&#x8981;&#x767B;&#x5F55;&#x6743;&#x9650;</li>
<li>&#x5224;&#x65AD;&#x672C;&#x5730;&#x662F;&#x5426;&#x5B58;&#x5728;token&#xFF0C;&#x5982;&#x679C;&#x5B58;&#x5728;token&#x5C31;next()&#xFF0C;&#x4E0D;&#x5B58;&#x5728;token&#x91CD;&#x5B9A;&#x5411;&#x5230;&#x767B;&#x5F55;&#x9875;</li>
</ol>
<h5 id="102-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x9879;&#x76EE;&#x5E38;&#x89C1;&#x4F18;&#x5316;&#x70B9;"><a name="102-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x9879;&#x76EE;&#x5E38;&#x89C1;&#x4F18;&#x5316;&#x70B9;" class="anchor-navigation-ex-anchor" href="#102-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x9879;&#x76EE;&#x5E38;&#x89C1;&#x4F18;&#x5316;&#x70B9;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="102-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x9879;&#x76EE;&#x5E38;&#x89C1;&#x4F18;&#x5316;&#x70B9;" class="plugin-anchor" href="#102-&#x2605;&#x2605;&#x2605;&#x2605;&#x2605;-vue&#x9879;&#x76EE;&#x5E38;&#x89C1;&#x4F18;&#x5316;&#x70B9;"><i class="fa fa-link" aria-hidden="true"></i></a>102. &#x2605;&#x2605;&#x2605;&#x2605;&#x2605; Vue&#x9879;&#x76EE;&#x5E38;&#x89C1;&#x4F18;&#x5316;&#x70B9;</h5>
<p>1&#x3001;&#x9996;&#x5C4F;&#x52A0;&#x8F7D;&#x4F18;&#x5316;</p>
<p>2&#x3001;&#x8DEF;&#x7531;&#x61D2;&#x52A0;&#x8F7D;</p>
<pre><code class="lang-js">{      
  path: <span class="hljs-string">&apos;/&apos;</span>,      
  name: <span class="hljs-string">&apos;home&apos;</span>,      
  component: () =&gt; <span class="hljs-keyword">import</span>(<span class="hljs-string">&apos;./views/home/index.vue&apos;</span>),      
  meta: { isShowHead: <span class="hljs-literal">true</span> }
}
</code></pre>
<p>3&#x3001;&#x5F00;&#x542F;&#x670D;&#x52A1;&#x5668; Gzip</p>
<p> &#x5F00;&#x542F; Gzip &#x5C31;&#x662F;&#x4E00;&#x79CD;&#x538B;&#x7F29;&#x6280;&#x672F;&#xFF0C;&#x9700;&#x8981;&#x524D;&#x7AEF;&#x63D0;&#x4F9B;&#x538B;&#x7F29;&#x5305;&#xFF0C;&#x7136;&#x540E;&#x5728;&#x670D;&#x52A1;&#x5668;&#x5F00;&#x542F;&#x538B;&#x7F29;&#xFF0C;&#x6587;&#x4EF6;&#x5728;&#x670D;&#x52A1;&#x5668;&#x538B;&#x7F29;&#x540E;&#x4F20;&#x7ED9;&#x6D4F;&#x89C8;&#x5668;&#xFF0C;&#x6D4F;&#x89C8;&#x5668;&#x89E3;&#x538B;&#x540E;&#x8FDB;&#x884C;&#x518D;&#x8FDB;&#x884C;&#x89E3;&#x6790;&#x3002;&#x9996;&#x5148;&#x5B89;&#x88C5; webpack &#x63D0;&#x4F9B;&#x7684;<code>compression-webpack-plugin</code>&#x8FDB;&#x884C;&#x538B;&#x7F29;,&#x7136;&#x540E;&#x5728; vue.config.js&#xFF1A; </p>
<pre><code class="lang-js"><span class="hljs-keyword">const</span> CompressionWebpackPlugin = <span class="hljs-built_in">require</span>(<span class="hljs-string">&apos;compression-webpack-plugin&apos;</span>)
<span class="hljs-keyword">const</span> productionGzipExtensions = [<span class="hljs-string">&apos;js&apos;</span>, <span class="hljs-string">&apos;css&apos;</span>]......plugins: [      
  <span class="hljs-keyword">new</span> CompressionWebpackPlugin(
    {        
      algorithm: <span class="hljs-string">&apos;gzip&apos;</span>,        
      test:     <span class="hljs-keyword">new</span> <span class="hljs-built_in">RegExp</span>(<span class="hljs-string">&apos;\\.(&apos;</span> + productionGzipExtensions.join(<span class="hljs-string">&apos;|&apos;</span>) +                 <span class="hljs-string">&apos;)$&apos;</span>),            
      threshold: <span class="hljs-number">10240</span>,        
      minRatio: <span class="hljs-number">0.8</span>      
       }
)]....
</code></pre>
<p>4&#x3001;&#x542F;&#x52A8; CDN &#x52A0;&#x901F;</p>
<p>&#x6211;&#x4EEC;&#x7EE7;&#x7EED;&#x91C7;&#x7528; cdn &#x7684;&#x65B9;&#x5F0F;&#x6765;&#x5F15;&#x5165;&#x4E00;&#x4E9B;&#x7B2C;&#x4E09;&#x65B9;&#x8D44;&#x6E90;&#xFF0C;&#x5C31;&#x53EF;&#x4EE5;&#x7F13;&#x89E3;&#x6211;&#x4EEC;&#x670D;&#x52A1;&#x5668;&#x7684;&#x538B;&#x529B;&#xFF0C;&#x539F;&#x7406;&#x662F;&#x5C06;&#x6211;&#x4EEC;&#x7684;&#x538B;&#x529B;&#x5206;&#x7ED9;&#x5176;&#x4ED6;&#x670D;&#x52A1;&#x5668;&#x70B9;&#x3002;</p>
<p>5&#x3001;&#x4EE3;&#x7801;&#x5C42;&#x9762;&#x4F18;&#x5316; </p>
<ul>
<li>computed &#x548C; watch &#x533A;&#x5206;&#x4F7F;&#x7528;&#x573A;&#x666F;<pre><code>computed&#xFF1A; &#x662F;&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#xFF0C;&#x4F9D;&#x8D56;&#x5176;&#x5B83;&#x5C5E;&#x6027;&#x503C;&#xFF0C;&#x5E76;&#x4E14; computed &#x7684;&#x503C;&#x6709;&#x7F13;&#x5B58;&#xFF0C;&#x53EA;&#x6709;&#x5B83;&#x4F9D;&#x8D56;&#x7684;&#x5C5E;&#x6027;&#x503C;&#x53D1;&#x751F;&#x6539;&#x53D8;&#xFF0C;&#x4E0B;&#x4E00;&#x6B21;&#x83B7;&#x53D6; computed &#x7684;&#x503C;&#x65F6;&#x624D;&#x4F1A;&#x91CD;&#x65B0;&#x8BA1;&#x7B97; computed &#x7684;&#x503C;&#x3002;&#x5F53;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x8FDB;&#x884C;&#x6570;&#x503C;&#x8BA1;&#x7B97;&#xFF0C;&#x5E76;&#x4E14;&#x4F9D;&#x8D56;&#x4E8E;&#x5176;&#x5B83;&#x6570;&#x636E;&#x65F6;&#xFF0C;&#x5E94;&#x8BE5;&#x4F7F;&#x7528; computed&#xFF0C;&#x56E0;&#x4E3A;&#x53EF;&#x4EE5;&#x5229;&#x7528; computed &#x7684;&#x7F13;&#x5B58;&#x7279;&#x6027;&#xFF0C;&#x907F;&#x514D;&#x6BCF;&#x6B21;&#x83B7;&#x53D6;&#x503C;&#x65F6;&#xFF0C;&#x90FD;&#x8981;&#x91CD;&#x65B0;&#x8BA1;&#x7B97;&#xFF1B;
  watch&#xFF1A;&#x7C7B;&#x4F3C;&#x4E8E;&#x67D0;&#x4E9B;&#x6570;&#x636E;&#x7684;&#x76D1;&#x542C;&#x56DE;&#x8C03; &#xFF0C;&#x6BCF;&#x5F53;&#x76D1;&#x542C;&#x7684;&#x6570;&#x636E;&#x53D8;&#x5316;&#x65F6;&#x90FD;&#x4F1A;&#x6267;&#x884C;&#x56DE;&#x8C03;&#x8FDB;&#x884C;&#x540E;&#x7EED;&#x64CD;&#x4F5C;&#xFF1B;&#x5F53;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x5728;&#x6570;&#x636E;&#x53D8;&#x5316;&#x65F6;&#x6267;&#x884C;&#x5F02;&#x6B65;&#x6216;&#x5F00;&#x9500;&#x8F83;&#x5927;&#x7684;&#x64CD;&#x4F5C;&#x65F6;&#xFF0C;&#x5E94;&#x8BE5;&#x4F7F;&#x7528; watch&#xFF0C;&#x4F7F;&#x7528; watch &#x9009;&#x9879;&#x5141;&#x8BB8;&#x6211;&#x4EEC;&#x6267;&#x884C;&#x5F02;&#x6B65;&#x64CD;&#x4F5C; ( &#x8BBF;&#x95EE;&#x4E00;&#x4E2A; API )&#xFF0C;&#x9650;&#x5236;&#x6211;&#x4EEC;&#x6267;&#x884C;&#x8BE5;&#x64CD;&#x4F5C;&#x7684;&#x9891;&#x7387;&#xFF0C;&#x5E76;&#x5728;&#x6211;&#x4EEC;&#x5F97;&#x5230;&#x6700;&#x7EC8;&#x7ED3;&#x679C;&#x524D;&#xFF0C;&#x8BBE;&#x7F6E;&#x4E2D;&#x95F4;&#x72B6;&#x6001;&#x3002;&#x8FD9;&#x4E9B;&#x90FD;&#x662F;&#x8BA1;&#x7B97;&#x5C5E;&#x6027;&#x65E0;&#x6CD5;&#x505A;&#x5230;&#x7684;&#x3002;
</code></pre></li>
<li>v-if &#x548C; v-show &#x533A;&#x5206;&#x4F7F;&#x7528;&#x573A;&#x666F;
v-if &#x9002;&#x7528;&#x4E8E;&#x5728;&#x8FD0;&#x884C;&#x65F6;&#x5F88;&#x5C11;&#x6539;&#x53D8;&#x6761;&#x4EF6;&#xFF0C;&#x4E0D;&#x9700;&#x8981;&#x9891;&#x7E41;&#x5207;&#x6362;&#x6761;&#x4EF6;&#x7684;&#x573A;&#x666F;&#xFF1B;v-show &#x5219;&#x9002;&#x7528;&#x4E8E;&#x9700;&#x8981;&#x975E;&#x5E38;&#x9891;&#x7E41;&#x5207;&#x6362;&#x6761;&#x4EF6;&#x7684;&#x573A;&#x666F;&#x3002;&#x8FD9;&#x91CC;&#x8981;&#x8BF4;&#x7684;&#x4F18;&#x5316;&#x70B9;&#x5728;&#x4E8E;&#x51CF;&#x5C11;&#x9875;&#x9762;&#x4E2D; dom &#x603B;&#x6570;&#xFF0C;&#x6211;&#x6BD4;&#x8F83;&#x503E;&#x5411;&#x4E8E;&#x4F7F;&#x7528; v-if&#xFF0C;&#x56E0;&#x4E3A;&#x51CF;&#x5C11;&#x4E86; dom &#x6570;&#x91CF;&#x3002;</li>
<li>v-for &#x904D;&#x5386;&#x5FC5;&#x987B;&#x4E3A; item &#x6DFB;&#x52A0; key&#xFF0C;&#x4E14;&#x907F;&#x514D;&#x540C;&#x65F6;&#x4F7F;&#x7528; v-if
v-for &#x904D;&#x5386;&#x5FC5;&#x987B;&#x4E3A; item &#x6DFB;&#x52A0; key&#xFF0C;&#x5FAA;&#x73AF;&#x8C03;&#x7528;&#x5B50;&#x7EC4;&#x4EF6;&#x65F6;&#x6DFB;&#x52A0; key&#xFF0C;key &#x53EF;&#x4EE5;&#x552F;&#x4E00;&#x6807;&#x8BC6;&#x4E00;&#x4E2A;&#x5FAA;&#x73AF;&#x4E2A;&#x4F53;&#xFF0C;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x4F8B;&#x5982; item.id &#x4F5C;&#x4E3A; key
&#x907F;&#x514D;&#x540C;&#x65F6;&#x4F7F;&#x7528; v-if&#xFF0C;v-for &#x6BD4; v-if &#x4F18;&#x5148;&#x7EA7;&#x9AD8;&#xFF0C;&#x5982;&#x679C;&#x6BCF;&#x4E00;&#x6B21;&#x90FD;&#x9700;&#x8981;&#x904D;&#x5386;&#x6574;&#x4E2A;&#x6570;&#x7EC4;&#xFF0C;&#x5C06;&#x4F1A;&#x5F71;&#x54CD;&#x901F;&#x5EA6;&#x3002;</li>
</ul>
<p>6&#x3001;Webpack &#x5BF9;&#x56FE;&#x7247;&#x8FDB;&#x884C;&#x538B;&#x7F29;</p>
<p>7&#x3001;&#x907F;&#x514D;&#x5185;&#x5B58;&#x6CC4;&#x6F0F;</p>
<p>8&#x3001;&#x51CF;&#x5C11; ES6 &#x8F6C;&#x4E3A; ES5 &#x7684;&#x5197;&#x4F59;&#x4EE3;&#x7801;</p>
<h5 id="103-&#x2605;&#x2605;&#x2605;-vuex&#x548C;redux&#x6709;&#x4EC0;&#x4E48;&#x533A;&#x522B;&#xFF1F;&#x4ED6;&#x4EEC;&#x7684;&#x5171;&#x540C;&#x601D;&#x60F3;&#x3002;"><a name="103-&#x2605;&#x2605;&#x2605;-vuex&#x548C;redux&#x6709;&#x4EC0;&#x4E48;&#x533A;&#x522B;&#xFF1F;&#x4ED6;&#x4EEC;&#x7684;&#x5171;&#x540C;&#x601D;&#x60F3;&#x3002;" class="anchor-navigation-ex-anchor" href="#103-&#x2605;&#x2605;&#x2605;-vuex&#x548C;redux&#x6709;&#x4EC0;&#x4E48;&#x533A;&#x522B;&#xFF1F;&#x4ED6;&#x4EEC;&#x7684;&#x5171;&#x540C;&#x601D;&#x60F3;&#x3002;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="103-&#x2605;&#x2605;&#x2605;-vuex&#x548C;redux&#x6709;&#x4EC0;&#x4E48;&#x533A;&#x522B;&#xFF1F;&#x4ED6;&#x4EEC;&#x7684;&#x5171;&#x540C;&#x601D;&#x60F3;&#x3002;" class="plugin-anchor" href="#103-&#x2605;&#x2605;&#x2605;-vuex&#x548C;redux&#x6709;&#x4EC0;&#x4E48;&#x533A;&#x522B;&#xFF1F;&#x4ED6;&#x4EEC;&#x7684;&#x5171;&#x540C;&#x601D;&#x60F3;&#x3002;"><i class="fa fa-link" aria-hidden="true"></i></a>103. &#x2605;&#x2605;&#x2605; Vuex&#x548C;redux&#x6709;&#x4EC0;&#x4E48;&#x533A;&#x522B;&#xFF1F;&#x4ED6;&#x4EEC;&#x7684;&#x5171;&#x540C;&#x601D;&#x60F3;&#x3002;</h5>
<h5 id="redux&#x548C;vuex&#x533A;&#x522B;"><a name="redux&#x548C;vuex&#x533A;&#x522B;" class="anchor-navigation-ex-anchor" href="#redux&#x548C;vuex&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="redux&#x548C;vuex&#x533A;&#x522B;" class="plugin-anchor" href="#redux&#x548C;vuex&#x533A;&#x522B;"><i class="fa fa-link" aria-hidden="true"></i></a>Redux&#x548C;Vuex&#x533A;&#x522B;</h5>
<ul>
<li>Vuex&#x6539;&#x8FDB;&#x4E86;Redux&#x4E2D;&#x7684;Action&#x548C;Reducer&#x51FD;&#x6570;&#xFF0C;&#x4EE5;mutations&#x53D8;&#x5316;&#x51FD;&#x6570;&#x53D6;&#x4EE3;Reducer&#xFF0C;&#x65E0;&#x9700;switch&#xFF0C;&#x53EA;&#x9700;&#x5728;&#x5BF9;&#x5E94;&#x7684;mutation&#x51FD;&#x6570;&#x91CC;&#x6539;&#x53D8;state&#x503C;&#x5C31;&#x53EF;&#x4EE5;</li>
<li>Vuex&#x7531;&#x4E8E;Vue&#x81EA;&#x52A8;&#x91CD;&#x65B0;&#x6E32;&#x67D3;&#x7684;&#x7279;&#x6027;&#xFF0C;&#x65E0;&#x9700;&#x8BA2;&#x9605;&#x91CD;&#x65B0;&#x6E32;&#x67D3;&#x51FD;&#x6570;&#xFF0C;&#x53EA;&#x8981;&#x751F;&#x6210;&#x65B0;&#x7684;state&#x5C31;&#x53EF;&#x4EE5;</li>
<li>Vuex&#x6570;&#x636E;&#x6D41;&#x7684;&#x987A;&#x5E8F;&#x662F;:View&#x8C03;&#x7528;store.commit&#x63D0;&#x4EA4;&#x5BF9;&#x5E94;&#x7684;&#x8BF7;&#x6C42;&#x5230;Store&#x4E2D;&#x5BF9;&#x5E94;&#x7684;mutation&#x51FD;&#x6570; -- store&#x6539;&#x53D8;(vue&#x68C0;&#x6D4B;&#x5230;&#x6570;&#x636E;&#x53D8;&#x5316;&#x81EA;&#x52A8;&#x6E32;&#x67D3;)</li>
</ul>
<h5 id="&#x5171;&#x540C;&#x601D;&#x60F3;"><a name="&#x5171;&#x540C;&#x601D;&#x60F3;" class="anchor-navigation-ex-anchor" href="#&#x5171;&#x540C;&#x601D;&#x60F3;"><i class="fa fa-link" aria-hidden="true"></i></a><a name="&#x5171;&#x540C;&#x601D;&#x60F3;" class="plugin-anchor" href="#&#x5171;&#x540C;&#x601D;&#x60F3;"><i class="fa fa-link" aria-hidden="true"></i></a>&#x5171;&#x540C;&#x601D;&#x60F3;</h5>
<ul>
<li>&#x5355;&#x4E00;&#x7684;&#x6570;&#x636E;&#x6E90;</li>
<li>&#x53D8;&#x5316;&#x53EF;&#x4EE5;&#x9884;&#x6D4B;</li>
<li><code>&#x672C;&#x8D28;&#x4E0A;:</code>Redux&#x548C;Vuex&#x90FD;&#x662F;&#x5BF9;MVVM&#x601D;&#x60F3;&#x7684;&#x670D;&#x52A1;&#xFF0C;&#x5C06;&#x6570;&#x636E;&#x4ECE;&#x89C6;&#x56FE;&#x4E2D;&#x62BD;&#x79BB;&#x7684;&#x4E00;&#x79CD;&#x65B9;&#x6848;</li>
<li><code>&#x5F62;&#x5F0F;&#x4E0A;:</code>Vuex&#x501F;&#x9274;&#x4E86;Redux&#xFF0C;&#x5C06;store&#x4F5C;&#x4E3A;&#x5168;&#x5C40;&#x7684;&#x6570;&#x636E;&#x4E2D;&#x5FC3;&#xFF0C;&#x8FDB;&#x884C;&#x6570;&#x636E;&#x7BA1;&#x7406;</li>
</ul>

                                
                                </section>
                            
    </div>
    <div class="search-results">
        <div class="has-results">
            
            <h1 class="search-results-title"><span class='search-results-count'></span> results matching "<span class='search-query'></span>"</h1>
            <ul class="search-results-list"></ul>
            
        </div>
        <div class="no-results">
            
            <h1 class="search-results-title">No results matching "<span class='search-query'></span>"</h1>
            
        </div>
    </div>
</div>

                        </div>
                    </div>
                
            </div>

            
                
                <a href="../node/" class="navigation navigation-prev " aria-label="Previous page: Node.js">
                    <i class="fa fa-angle-left"></i>
                </a>
                
                
                <a href="../react/" class="navigation navigation-next " aria-label="Next page: React">
                    <i class="fa fa-angle-right"></i>
                </a>
                
            
        
    </div>

    <script>
        var gitbook = gitbook || [];
        gitbook.push(function() {
            gitbook.page.hasChanged({"page":{"title":"Vue.js","level":"1.5","depth":1,"next":{"title":"React","level":"1.6","depth":1,"path":"react/index.md","ref":"./react/index.md","articles":[]},"previous":{"title":"Node.js","level":"1.4","depth":1,"path":"node/index.md","ref":"./node/index.md","articles":[]},"dir":"ltr"},"config":{"plugins":["-sharing","splitter","expandable-chapters-small","anchors","github","github-buttons","sharing-plus","anchor-navigation-ex","favicon","insert-logo"],"styles":{"website":"./styles/website.css"},"pluginsConfig":{"github":{"url":"https://github.com/lurongtao/felixbooks-interview"},"splitter":{},"search":{},"sharing-plus":{"qq":false,"all":["facebook","google","twitter","instapaper","linkedin","pocket","stumbleupon"],"douban":false,"facebook":true,"weibo":false,"instapaper":false,"whatsapp":false,"hatenaBookmark":false,"twitter":true,"messenger":false,"line":false,"vk":false,"pocket":true,"google":false,"viber":false,"stumbleupon":false,"qzone":false,"linkedin":false},"lunr":{"maxIndexSize":1000000,"ignoreSpecialCharacters":false},"fontsettings":{"theme":"white","family":"sans","size":2},"highlight":{},"anchor-navigation-ex":{"associatedWithSummary":true,"float":{"floatIcon":"fa fa-navicon","level1Icon":"","level2Icon":"","level3Icon":"","showLevelIcon":false},"mode":"float","multipleH1":true,"pageTop":{"level1Icon":"","level2Icon":"","level3Icon":"","showLevelIcon":false},"printLog":false,"showGoTop":true,"showLevel":false},"favicon":{"shortcut":"./source/images/favicon.jpg","bookmark":"./source/images/favicon.jpg","appleTouch":"./source/images/apple-touch-icon.jpg","appleTouchMore":{"120x120":"./source/images/apple-touch-icon.jpg","180x180":"./source/images/apple-touch-icon.jpg"}},"github-buttons":{"buttons":[{"user":"lurongtao","repo":"felixbooks-interview","type":"star","size":"small","count":true}]},"expandable-chapters-small":{},"sharing":{"qq":false,"all":["google","facebook","weibo","twitter","qq","qzone","linkedin","pocket"],"douban":false,"facebook":false,"weibo":false,"instapaper":false,"whatsapp":false,"hatenaBookmark":false,"twitter":false,"messenger":false,"line":false,"vk":false,"pocket":false,"google":false,"viber":false,"stumbleupon":false,"qzone":false,"linkedin":false},"theme-default":{"styles":{"website":"styles/website.css","pdf":"styles/pdf.css","epub":"styles/epub.css","mobi":"styles/mobi.css","ebook":"styles/ebook.css","print":"styles/print.css"},"showLevel":false},"anchors":{},"insert-logo":{"url":"/felixbooks-interview2/images/logo-interview.png","style":"background: skyblue; width: 100%; height: 100%;"}},"theme":"default","author":"古艺散人","pdf":{"pageNumbers":true,"fontSize":12,"fontFamily":"Arial","paperSize":"a4","chapterMark":"pagebreak","pageBreaksBefore":"/","margin":{"right":62,"left":62,"top":56,"bottom":56}},"structure":{"langs":"LANGS.md","readme":"README.md","glossary":"GLOSSARY.md","summary":"SUMMARY.md"},"variables":{},"title":"千锋大前端小册-企业面试真题","language":"zh-hans","links":{},"gitbook":"3.2.3","description":"Electron 入门与实战"},"file":{"path":"vue/index.md","mtime":"2021-05-06T23:28:32.731Z","type":"markdown"},"gitbook":{"version":"3.2.3","time":"2021-05-06T23:31:20.692Z"},"basePath":"..","book":{"language":""}});
        });
    </script>
</div>

        
    <script src="../gitbook/gitbook.js"></script>
    <script src="../gitbook/theme.js"></script>
    
        
        <script src="../gitbook/gitbook-plugin-splitter/splitter.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-expandable-chapters-small/expandable-chapters-small.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-github/plugin.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-github-buttons/plugin.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-sharing-plus/buttons.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-insert-logo/plugin.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-search/search-engine.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-search/search.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-lunr/lunr.min.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-lunr/search-lunr.js"></script>
        
    
        
        <script src="../gitbook/gitbook-plugin-fontsettings/fontsettings.js"></script>
        
    

    </body>
</html>

